Fetstil Fetstil Kursiv Understrykning linje färgläggning tabellverk Punktlista Nummerlista Vänster Centrerat högerställt Utfyllt Länk Bild htmlmode
  • Forum & Blog
    • Forum - översikt
      • .Net
        • asp.net generellt
        • c#
        • vb.net
        • f#
        • silverlight
        • microsoft surface
        • visual studio .net
      • databaser
        • sql-server
        • databaser
        • access
        • mysql
      • mjukvara klient
        • datorer och komponenter
        • nätverk, lan/wan
        • operativsystem
        • programvaror
        • säkerhet, inställningar
        • windows server
        • allmänt
        • crystal reports
        • exchange/outlook
        • microsoft office
      • mjukvara server
        • active directory
        • biztalk
        • exchange
        • linux
        • sharepoint
        • webbservers
        • sql server
      • appar (win/mobil)
      • programspråk
        • c++
        • delphi
        • java
        • quick basic
        • visual basic
      • scripting
        • asp 3.0
        • flash actionscript
        • html css
        • javascript
        • php
        • regular expresssion
        • xml
      • spel och grafik
        • DirectX
        • Spel och grafik
      • ledning
        • Arkitektur
        • Systemutveckling
        • krav och test
        • projektledning
        • ledningsfrågor
      • vb-sektioner
        • activeX
        • windows api
        • elektronik
        • internet
        • komponenter
        • nätverk
        • operativsystem
      • övriga forum
        • arbete karriär
        • erbjuda uppdrag och tjänster
        • juridiska frågor
        • köp och sälj
        • matematik och fysik
        • intern information
        • skrivklåda
        • webb-operatörer
    • Posta inlägg i forumet
    • Chatta med andra
  • Konto
    • Medlemssida
    • Byta lösenord
    • Bli bonsumedlem
    • iMail
  • Material
    • Tips & tricks
    • Artiklar
    • Programarkiv
  • JOBB
  • Student
    • Studentlicenser
  • KONTAKT
    • Om pellesoft
    • Grundare
    • Kontakta oss
    • Annonsering
    • Partners
    • Felanmälan
  • Logga in

Hem / Artiklar / Titel på artikeln

Skapa ett enkelt forum

Postad 2001-08-23 av Michael Karlsson i sektionen ASP.NET, C#, Okategoriserat med 0 Kommentarer | Läst av: 5753, Betyg: 80%

Förord

Ett enkelt forum fungerar ungefär som en gästbok, dock med lite skillnader. Just detta forumet ger dig möjlighet att skapa ett diskussionsämne och sedan låta folk svara inom detta. Inget avancerat alls, men man får en liten uppfattning och grunden till hur man fortbygger sitt forum till ett större och mer avancerat sådant. Låt oss starta!
Innehåll
  » Databasen
  » Filen Default.asp
  » Filen Config.asp
  » Filen skapa.asp
  » Filen Skapat.asp
  » Filen Meddelande.asp
  » Filen Svara.asp
  » Sammanfattning
  » Fil att tanka
  » Var denna artikeln användbar?


Databasen

Databasen är en access-databas. Vi ska ha två tabeller, meddelande och svar. Meddelande ska se ut såhär: Det ska finnas fem fält, dessa är SvarID(Räknare), Titel(Text), namn(Text), Epost(text), Meddelande(PM). Svar-tabellen ser då ut sähär: Här gäller 4 fält, SvarID(Tal), Namn(Text), Email(Text), Meddelande(PM).


Filen Default.asp

Nu har det blivit dags att gå igenom filerna, och vi startar med Default.asp.



<%

set connection = Server.createobject("adodb.connection")
set rs = server.createobject("adodb.recordset")
sql = "select * from meddelande"
connection.open strconn, 1, 2
rs.open sql, connection

if rs.eof <> "" then
do until rs.eof

%>
<%
ID = rs("svarid")
%>
<%=rs("titel")%>
<%
response.write "Inlagt av " & rs("namn") & "
"

rs.movenext
loop
end if


%>

 


 


Vill Du själv skapa ett ämne att diskutera? Klicka då Här

Denna filen ska nog inte innebära några problem för er. Det den gör är att titta i config.asp efter koppling till databasen, koppla sig och sedan ta fram den data som finns i tabellen meddelande. Det som sedan sker är att det skapas en länk till meddelandet med det SvarID som gäller. Sidan ger även möjlighet till att skapa eget diskussionsämne.


Filen Config.asp

Filen med det viktigaste i formut. Denna lilla rad håller kontakt med databasen, och i och med att vi bara har kopplingen i denna filen slipper man skriva om allting varje gång man behöver något i databasen.


<%
strConn = "DRIVER={Microsoft Access Driver (*.mdb)}; DBQ=" & Server.Mappath("forum.mdb") & ";"
%>


Filen skapa.asp

Som vi såg på default-sidan så fanns det en länk till skapa.asp. Denna sida ger en möjlighet att skapa ett eget ämne att prata om.


























Skapa ett eget ämne här
Namn
Titel
Epost
Meddelande






Filen Skapat.asp

Som det låter på filnamnet så är det här meddelandet skapas i databasen.




<%

if NOT request.querystring("txtnamn") = "" AND NOT request.querystring("titel") = "" AND NOT request.querystring("meddelande") = "" then

dim namn
dim titel
dim epost
dim meddelande


namn = request.querystring("txtnamn")
titel = request.querystring("titel")
epost = request.querystring("txtEpost")
meddelande = request.querystring("meddelande")

set connection = Server.createobject("ADODB.Connection")
set rs = Server.Createobject("ADODB.Recordset")

connection.open strconn

rs.open "meddelande", strconn, adopendynamic, adlockpessimistic



rs.AddNew

rs("namn") = namn
rs("titel") = titel
rs("epost") = epost
rs("meddelande") = meddelande
rs.update
response.redirect "default.asp"

else
response.write "Du måste fylla i namn, titel och meddelande för att kunna posta något"
end if
%>

Vi ser även att om man i det tidigare skriptet Skapa.asp glömde fylla i namn, titel eller meddelande så får man istället upp ett felmeddelande.


Filen Meddelande.asp

Här ser vi meddelandet som den förste personen skapade, och sedan alla dess svar, mycket enkelt, men endock ett fungerande forum.




<%

set connection = server.createobject("Adodb.connection")
set rs = server.createobject("adodb.recordset")
set rs1 = server.createobject("adodb.recordset")

sql = "select * from svar where svarid = " & request.querystring("fid")
sql1 = "select * from meddelande where svarid= " & request.querystring("fid")
connection.open strconn
rs.open sql, strconn
rs1.open sql1, strconn

%>
<%

response.write "HUVUDMEDDELANDE START
"
response.write "Namn " &rs1("namn") & "
"
response.write "Titel : " &rs1("Titel") & "
"
response.write "Epost : " & rs1("epost") & "
"
response.write "Meddelande: "&rs1("meddelande") & "
"
response.write "HUVUDMEDDELANDE SLUT

 

"


if rs.eof <> "" then
do until rs.eof
%>

<%



%>
svar <%=antal%>












Namn<%=rs("namn")%>
Epost<%=rs("email")%>
Meddelande
<%=rs("meddelande")%>


 




<%
rs.movenext
loop
end if
%>

Svara på detta meddelande

 


" method="post">












Namn
Epost
Meddelande





Filen Svara.asp

Då var vi framme vid den sista filen, och även en bland de viktigaste.





<%



if NOT request.form("txtname") = "" AND NOT request.form("txtmeddelande") = "" then

set connection = server.createobject("Adodb.connection")
set rs = server.createobject("adodb.recordset")
connection.open strconn

rs.open "svar", strconn, adopendynamic, adlockpessimistic

svarID = request.Querystring("fid")
namn = request.form("txtName")
epost =request.form("txtEpost")
meddelande = request.form("txtmeddelande")
rs.addnew
rs("svarid") = svarID
rs("namn") = namn
rs("email") = epost
rs("meddelande") = meddelande
rs.update
rs.close
connection.close
response.redirect request.servervariables("HTTP_REFERER")

else
response.write "Du måste fylla i namn och meddelande för att det ska bli sparat."
end if
%>

Om alla fälten var ifyllda, så startas kopplingen till databasen, den sparar först ID-numret som den sedan använder för att hålla kontakten mellan det första meddelandet, och svaret. Så fort allt har lagrats förs man tillbaks till sidan med det första meddelandet.


Sammanfattning


Nu har du skrivit ditt första Forum. Som du säket märkte var det mycket simpelt, men med lite fantasi kan man lätt bygga ut det och ge det många möjligheter. Exempel på saker man kan lägga till är t.ex. vilket datum meddelandet postades, hur många svar det finns och när det senaste postades. Dock hoppas jag att detta har givit er en inblick och att ni nu förstår uppbyggnaden hos ett enkelt forum.


Fil att tanka

Fil: miniforum.zip


Var denna artikeln användbar?

Om du gör någon intressant (eller kanske något konstigt fel) på grund av detta material så skicka gärna det med ett mail eller bifoga en länk till mig så presenterar jag detta som ytterligare exempelfiler för kursen. Om detta innehållet är felaktigt eller du lärt dig fler finesser så skriv gärna en rad eller varför inte en egen kurs baserat på dina erfarenheter. Sänd gärna in dina tips till denna kurs.

/Michael Karlsson
Upp

0 Kommentarer

Skriv en kommentar på artikeln

Ditt betyg på artikeln



Kommentar:





Nyligen

  • 09:09 Vill du köpa medicinska tester?
  • 12:47 Vem beviljar assistansen – kommune
  • 14:17 Någon med erfarenhet av hemstädnin
  • 14:14 Bör man använda sig av en båtförme
  • 14:12 Finns det någon intressant hundblo
  • 14:25 Tips på verktyg för att skapa QR-k
  • 14:23 Tips på verktyg för att skapa QR-k
  • 20:52 Fungerer innskuddsbonuser egentlig

Sidor

  • Hem
  • Bli bonusmedlem
  • Läs artiklar
  • Chatta med andra
  • Sök och erbjud jobb
  • Kontakta oss
  • Studentlicenser
  • Skriv en artikel

Statistik

Antal besökare:
Antal medlemmar:
Antal inlägg:
Online:
På chatten:
4 569 158
27 952
271 704
1 021
0

Kontakta oss

Frågor runt konsultation, rådgivning, uppdrag, rekrytering, annonsering och övriga ärenden. Ring: 0730-88 22 24 | pelle@pellesoft.se

© 1986-2013 PelleSoft AB. Last Build 4.1.7169.18070 (2019-08-18 10:02:21) 4.0.30319.42000
  • Om
  • Kontakta
  • Regler
  • Cookies