HtmlEncode on Post for ASP.Net MVC 3 Html.TextAreaFor

前端 未结 2 2181
感情败类
感情败类 2021-02-20 09:14

I have an ASP.Net MVC 3 page in which I have an Html.TextAreaFor control, see code below. If I try to submit the page to the http post action with text in angle brackets like:

相关标签:
2条回答
  • 2021-02-20 09:48

    You could decorate your RequestText property on the view model with the AllowHtmlAttribute:

    [AllowHtml]
    public string RequestText { get; set; }
    

    This way you are authorizing the client to submit HTML for this property only.

    As far as the <%: %> syntax is concerned, this is used to HTML encode some value before outputting it to the page. It is used to protect against XSS attacks. It is irrelevant in your case because you are not outputting to the page, you are receiving HTML characters in a request.

    0 讨论(0)
  • 2021-02-20 09:50

    Basically right now, you're encoding the content of the TextAreaFor on the output. This doesn't help you in the slightest since you're trying to deal with input

    If you want to submit "potentially dangerous" content, you need to either

    1) decorate the RequestText property within your ViewModel with [AllowHtml]. (preferred)

    [AllowHtml]
    public string RequestText { get; set; }
    

    2) disable validateRequest

    <system.web>
        <compilation debug="true" targetFramework="4.0" />
        <httpRuntime requestValidationMode="2.0" />
    </system.web>
    

    Then you must ensure you're appropriately sanitizing that data and/or encoding it in your controller before submitting it to your Repository Layer or Database.

    0 讨论(0)
提交回复
热议问题