javascript - 如何使用asp.net处理html页面中的表单数据
问题描述
有时我需要处理来自仅 html 网站的联系表单的数据,该网站有托管限制,无法运行 asp.net 代码。
在这种情况下如何处理数据?(在更简单的情况下,发送电子邮件)
解决方案
为了实现这一点,我通常将数据重定向到一个 asp.net 处理程序(托管在另一个运行 asp.net 的服务器上)。
这是我的做法:
html表单:
<form name="ajax-form" id="ajax-form" action="http://somedomain.com/handler.ashx" method="post">
<label for="name">
Nome: *
<span class="error" id="err-name">please enter your name</span>
</label>
<input name="name" id="name" type="text" />
<label for="email">
E-Mail: *
<span class="error" id="err-email">please enter your e-mail</span>
<span class="error" id="err-emailvld">the e-mail does not have a valid format</span>
</label>
<input name="email" id="email" type="text" />
<label for="message">Message:</label>
<textarea name="message" id="message"></textarea>
<div id="button-con"><button class="send_message" id="send">Send</button></div>
<div class="error text-align-center" id="err-form">Error on form. Please check!</div>
<div class="error text-align-center" id="err-timedout">Time out connecting to server...</div>
<div class="error" id="err-state"></div>
</form>
加载 jquery 后,我添加了这个 javascript:
jQuery(document).ready(function ($) {
$('#send').click(function(){
$('.error').fadeOut('slow');
var error = false;
var name = $('input#name').val();
if(name == "" || name == " ") {
$('#err-name').fadeIn('slow');
error = true;
}
var email_compare = /^([a-z0-9_.-]+)@([da-z.-]+).([a-z.]{2,6})$/;
var email = $('input#email').val();
if (email == "" || email == " ") {
$('#err-email').fadeIn('slow');
error = true;
}else if (!email_compare.test(email)) {
$('#err-emailvld').fadeIn('slow');
error = true;
}
if(error == true) {
$('#err-form').slideDown('slow');
return false;
}
var obj = {};
obj.name = name;
obj.email = email;
obj.message = $("#message").val();
var jsonData = JSON.stringify(obj);
console.log(jsonData);
$.ajax({
type: "POST",
url: $('#ajax-form').attr('action'),
data: jsonData,
timeout: 6000,
error: function(request,error) {
if (error == "timeout") {
$('#err-timedout').slideDown('slow');
}
else {
$('#err-state').slideDown('slow');
$("#err-state").html('An error occurred: ' + error + '');
}
},
success: function() {
$('#ajax-form').slideUp('slow');
$('#ajaxsuccess').slideDown('slow');
}
});
return false;
});
});
最后,我的 handler.ashx 的代码:
<%@ WebHandler Language="VB" Class="Handler" %>
Imports System.Web.Script.Serialization
Imports System.IO
Public Class Handler : Implements IHttpHandler
Public Sub ProcessRequest(ByVal context As HttpContext) Implements IHttpHandler.ProcessRequest
context.Response.ContentType = "text/plain"
Try
Dim strJson As String = New StreamReader(context.Request.InputStream).ReadToEnd()
Dim objUsr As userInfo = Deserialize(Of userInfo)(strJson)
If objUsr IsNot Nothing Then
Dim name As String = objUsr.name
Dim email As String = objUsr.email
Dim message As String = objUsr.message
'here you treat you data, some send email function using the data collected
context.Response.Write(String.Format("Name :{0} , email={1}, message={2}", name, email, message))
Else
context.Response.Write("No Data")
End If
Catch ex As Exception
context.Response.Write("Error :" & ex.Message)
End Try
End Sub
Public ReadOnly Property IsReusable() As Boolean Implements IHttpHandler.IsReusable
Get
Return False
End Get
End Property
Public Class userInfo
Public Property name As String
Public Property email As String
Public Property message As String
End Class
Public Function Deserialize(Of T)(ByVal context As String) As T
Dim jsonData As String = context
Dim obj = CType(New JavaScriptSerializer().Deserialize(Of T)(jsonData), T)
Return obj
End Function
End Class
我希望这对你有用...
推荐阅读
- javascript - 如何在 ul > li 中查找所有类名
- maven - dspace 的 maven 包问题
- c - Understanding promotions (type conversions)
- android - 如何解决空引用错误?我是新手
- asp.net-core - 使用 ILoggerProvider 基于 .NetCore 2.2 中的环境进行日志记录
- windows - 无法在本地机器上启动 kafka
- android - 应用 span 数次
- python - TypeError:convertDocument() 接受 1 个位置参数,但给出了 2 个
- c - 如何使用 GDAL 对带有 C/C++ 的 shapefile 进行光栅化?
- regex - 在熊猫系列上循环正则表达式