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 / Forum översikt / inlägg

Posta nytt inlägg


Server.HTMLEncode

Postades av 2007-05-17 11:00:24 - Mattias Svensson, i forum asp - allmänt, Tråden har 5 Kommentarer och lästs av 2858 personer

Okej. så här är problemet -
för att undvika att användare oavsiktligen sabbar layouten genom att använda tecken som " och > i sina noteringar så kör jag Server.HTMLEncode på allt som skrivs ut till sidan, så även på de ställen där jag har en redigerafunktion och tidigare värde skrivs in i formulärfältet

<Input type=text name=bla value=<%=Server.HTMLEncode(request.querystring("namn"))%>
<Input type=text name=blabla value=<%=Server.HTMLEncode(request.querystring("namn"))%>

Men resultatet blir ju här att om användaren då bara redigerar fältet bla och inte blabla och sedan sparar, så följer ju HTML-tecknen för åäö och allt annat med in i databasen. Det är väl okej så långt, men om användaren sedan skall använda sökfunktionen och söka i de data han lagrat i databasen, ex. kanske frågan ser ut så här

SELECT * FROM friend WHERE bla LIKE form_input

om min användare nu söker efter allt som innehåller ett <b>å</b>, så kommer hans poster inte upp för de är i databasen lagrade som &49da; eller någon sådan kod...

Problemet uppfattat? Vad göra..?


Svara

Sv: Server.HTMLEncode

Postades av 2007-05-17 11:30:33 - Thomas Vanhaniemi

Du ska inte köra Server.HTMLEncode på den data du sätter in i databasen utan bara på den data som skrivs ut på sidorna. HTMLEncode gör ju att alla specialtecken som används i HTML konverteras till andra tecken så de inte stör.

När data sedan postas tillbaka till servern kommer dessa tecken inte att finnas eftersom det är tecknen i "klartext", till exempel < som postas. När du sedan sätter in data i databasen kommer dessa tecken att läggas in dit också, i sin ursprungliga form.

HTMLEncode gör alltså bara så att webbläsaren "förstår" HTML koden på rätt sätt.

Sen, för att vara petig är det bra om du anger alla attribut omgivna av citattecken (") och med små bokstäver samt se till att avsluta alla taggar på ett eller annat sätt. Detta medför att du slipper konstiga problem i framtiden.

Till exempel:

<Input type=text name=bla value=<%=Server.HTMLEncode(request.querystring("namn"))%>
blir
<input type="text" name="bla" value="<%=Server.HTMLEncode(request.querystring("namn"))%>" />


Svara

Sv:Server.HTMLEncode

Postades av 2007-05-17 11:36:07 - Mattias Svensson

Jo... läs frågan igen =) du förstod nog inte riktigt...

så i ett ändraformulär så vill jag skicka med tidigare sparade värden, yes? gör det genom att sätta value= i input-taggen. Men, om användaren har sparat något i stil med <b>">haha, jag äger! </TABLE></TABLE></b> så kommer min layout att pajas.

Lösning: kör Server.HTMLEncode på det som sätts i value= i input-taggen. MEN - om användaren då sparar formuläret utan att ändra det fältet som lästs in och "säkrats" med HTMLEncode så kommer skräpet in i databasen, och blir inte sökbart med vanliga åäö osv..


Svara

Sv: Server.HTMLEncode

Postades av 2007-05-17 11:48:05 - Thomas Vanhaniemi

Det ska inte komma in i databasen om du gjort rätt.

Jag förstod nog vad du menade, men förstår inte hur du lyckas få in den "säkrade" strängen i databasen då all data, även om du använt dig av Server.HTMLEncode, när det postas kommer att genom Request.Form("namn") att returnera texten i klartext.

Är inte problemet något i stil med att du när du tar emot posten gör något liknande
<code>
Dim variabel = Server.HTMLEncode(Request.Form("namn"))

'Sedan sätts variabel in som parameter till en SQL fråga som sparar detta i databasen.
</code>

Svårt att säga utan att ha sett koden som vid postning hämtar data och bearbetar det innan det sätts in i databasen.


Svara

Sv:Server.HTMLEncode

Postades av 2007-05-17 11:52:47 - Mattias Svensson

Aha - så när man kör en request.form så kodas det automatiskt tillbaka till <>åäö istället för den konstiga koden för dessa tecken, okej.. uppfattat =)


Svara

Sv: Server.HTMLEncode

Postades av 2007-05-17 11:56:20 - Thomas Vanhaniemi

Stämmer bra, var det jag försökte förklara i första posten ;)


Svara

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 159
27 952
271 704
931
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