原文:http://www.cnblogs.com/andiki/archive/2010/05/17/1737254.html

jquery ajax调用webservice(C#)要注意的几个事项:

1、web.config里需要配置2个地方

<httpHandlers>       <remove verb="*" path="*.asmx"/>       <add verb="*" path="*.asmx" validate="false" type="System.Web.Script.Services.ScriptHandlerFactory, System.Web.Extensions, Version=1.0.61025.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"/>     </httpHandlers> 在<system.web></system.web>之间加入 <webServices>       <protocols>         <add name="HttpPost" />         <add name="HttpGet" />       </protocols>     </webServices>

2.正确地编写webserivce的代码


 /// <summary> /// UserValidate 的摘要说明 /// </summary>  [WebService(Namespace = "http://tempuri.org/")] [WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)] [System.ComponentModel.ToolboxItem(false)] // 若要允许使用 ASP.NET AJAX 从脚本中调用此 Web 服务,请取消对下行的注释。  [System.Web.Script.Services.ScriptService] public class UserValidate : System.Web.Services.WebService { DFHon.Content.Common.rootPublic rp = new DFHon.Content.Common.rootPublic(); [WebMethod] [ScriptMethod(ResponseFormat = ResponseFormat.Json)] public string ValidateUserLogState() { string result = ""; HttpCookie cookie = HttpContext.Current.Request.Cookies["DHFonMenberInfo"]; if (cookie != null) { string username = System.Web.HttpUtility.UrlDecode(cookie["MenberName"]); int ipoint = 0; int gpoint = 0; try { DataTable dt = UserBll.ExecuteUserAllInfo(username);
                    if (dt.Rows.Count > 0)                     {                         ipoint = int.Parse(dt.Rows[0]["iPoint"].ToString());                         gpoint = int.Parse(dt.Rows[0]["gPoint"].ToString());                     }                 }                 catch                 { }                 result = "{'user':{'id':'" + cookie["UserId"] + "','name':'" + username + "','message':'" + rp.getUserMsg(DFHon.Global.CurrentCookie.UserName) + "','ipoint':'" + ipoint.ToString() + "','gpoint':'" + gpoint.ToString() + "'}}";             }             else             {                 result = "{'user':{'id':'0','name':'','message':'0','ipoint':'0','gpoint':'0'}}";             }             return result;         }
        [WebMethod]         [ScriptMethod(ResponseFormat = ResponseFormat.Json)]         public string UserLogin(string userName, string userPwd)         {             string returnVal = "";             try             {                 GlobalUserInfo info;                 DFHon.Content.UserLogin _UserLogin = new DFHon.Content.UserLogin();                 EnumLoginState state = _UserLogin.PersonLogin(HttpUtility.UrlDecode(userName), userPwd, out info);                 if (state == EnumLoginState.Succeed)                 {                     DFHon.Global.CurrentCookie.Set(info);                     DFHon.API.PDO.DiscuzNT.PassportLogin.UserLogin(Server.UrlDecode(userName), userPwd, -1);                     int ipoint = 0;                     int gpoint = 0;                     DataTable dt = UserBll.ExecuteUserAllInfo(userName);
                    if (dt.Rows.Count > 0)                     {                         ipoint = int.Parse(dt.Rows[0]["iPoint"].ToString());                         gpoint = int.Parse(dt.Rows[0]["gPoint"].ToString());                     }                     returnVal = "{'user':{'id':'" + info.UserId.ToString() + "','name':'" + info.UserName + "','message':'" + rp.getUserMsg(userName) + "','ipoint':'" + ipoint.ToString() + "','gpoint':'" + gpoint.ToString() + "'}}";                 }                 else                 {                     int ids = 0;//状态:-2用户被锁定 -1用户名密码错误                     switch (state)                     {                         case EnumLoginState.Err_Locked:                             ids = -2;                             break;                         case EnumLoginState.Err_UserNameOrPwdError:                             ids = -1;                             break;                         default:                             break;                     }                     returnVal = "{'user':{'id':'" + ids + "','name':'','message':'0','ipoint':'0','gpoint':'0'}}";                 }             }             catch             {                 returnVal = "{'user':{'id':'0','name':'','message':'0','ipoint':'0','gpoint':'0'}}";             }             return returnVal;         }         [WebMethod]         public string UserLogout()         {             if (HttpContext.Current.Request.Cookies["DHFonMenberInfo"] != null)             {                 HttpCookie cookie = new HttpCookie("DHFonMenberInfo");                 cookie.Expires = System.DateTime.Now.AddDays(-1);                 cookie.Domain = DFHon.Config.BaseConfig.getV("weblogin");                 HttpContext.Current.Response.AppendCookie(cookie);             }             return "1";         }         DFHon.Content.user UserBll = new DFHon.Content.user();         [WebMethod]         public string ValidateUserEmail(string email)         {             string result = "0";//返回的结果 -2邮箱为空 -1邮箱格式不正确 0邮箱存在 1填写正确             if (string.IsNullOrEmpty(email))             {                 result = "-2";//邮箱为空             }             else if (!IsValidEmail(email))             {                 result = "-1";//邮箱格式不正确             }             else if (UserBll.sel_useremail(email) > 0)             {                 result = "0";//邮箱存在             }             else             {                 result = "1";//可以注册             }             return result;         }
        [WebMethod]         public string ValidateUserName(string username)         {             string result = "0";//返回值:-1用户名长度为2-16;0用户名存在;1可以注册             if (username == "" || username == null || username.Length < 2 || username.Length > 16)             {                 result = "-1";             }             else if (UserBll.sel_username(username) != 0)             {                 result = "0";             }             else             {                 result = "1";             }             return result;         }
        public bool IsValidEmail(string strIn)         { // Return true if strIn is in valid e-mail format.              return System.Text.RegularExpressions.Regex.IsMatch(strIn, @"^([\w-\.]+)@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.)|(([\w-]+\.)+))([a-zA-Z]{2,4}|[0-9]{1,3})(\]?)$");         }     }

3、前台JQuery代码


<script>         $(function() {             $("#userloging").show();             //登录框处理开始             //加载登录状态             $.ajax({                 type: "POST", //访问WebService使用Post方式请求                 contentType: "application/json;charset=utf-8", //WebService 会返回Json类型                 url: "/API/Service/UserValidate.asmx/ValidateUserLogState", //调用WebService                 data: "{}", //Email参数                 dataType: 'json',                 beforeSend: function(x) { x.setRequestHeader("Content-Type", "application/json; charset=utf-8"); },                 error: function(x, e) { },                 success: function(response) { //回调函数,result,返回值                     $("#userloging").hide();                     var json = eval('(' + response.d + ')');                     var userid = json.user.id;                     if (userid > 0) {                         $("#spanusername").html(json.user.name);                         $("#spanmessagenum").html(json.user.message);                         $("#userloginsucced").show();                         $("#userloginbox").hide();                     }                 }             });             //登录             $("#userlogbutton").click(function() {                                 var username = $("#username").val();                 var userpwd = $("#userpassword").val();                 if (username != "" && userpwd != "") {                     $("#userloging").show();                     $.ajax({                         type: "POST", //访问WebService使用Post方式请求                         contentType: "application/json;charset=utf-8", //WebService 会返回Json类型                         url: "/API/Service/UserValidate.asmx/UserLogin", //调用WebService                         data: "{userName:'" + username + "',userPwd:'" + userpwd + "'}", //Email参数                         dataType: 'json',                         beforeSend: function(x) { x.setRequestHeader("Content-Type", "application/json; charset=utf-8"); },                         error: function(x, e) {                         },                         success: function(result) { //回调函数,result,返回值                             $("#userloging").hide();                             var json = eval('(' + result.d + ')');                             var userid = json.user.id;                             if (userid > 0) {                                 $("#spanusername").html(json.user.name);                                 $("#spanmessagenum").html(json.user.message);                                 $("#userloginsucced").show();                                 $("#userloginbox").hide();                             }                             else {                                 switch (userid) {                                     case -2:                                         alert("用户被锁定!请30分钟后再登录!");                                         $("#username").focus();                                         break;                                     case -1:                                         alert("用户名或密码错误!请核对您的用户名和密码!");                                         $("#userpassword").focus();                                         break;                                     default:                                         alert("登录失败!请核对您的用户名和密码之后重试!");                                         $("#userpassword").focus();                                         break;                                 }                             }                         }                     });                 }                 else if (username == "") {                     alert("用户名不能为空!");                     $("#username").focus();                 }                 else if (userpwd == "") {                     alert("密码不能为空!");                     $("#userpassword").focus();                 }             });             //退出             $("#logout").click(function() {                 $("#userloging").show();                 $.ajax({                     type: "POST", //访问WebService使用Post方式请求                     contentType: "application/json;utf-8", //WebService 会返回Json类型                     url: "/API/Service/UserValidate.asmx/UserLogout", //调用WebService                     data: "{}", //Email参数                     dataType: 'json',                     beforeSend: function(x) { x.setRequestHeader("Content-Type", "application/json; charset=utf-8"); },                     success: function(result) { //回调函数,result,返回值                         $("#userloging").hide();                         if (result.d > 0) {                             $("#userloginsucced").hide();                             $("#userloginbox").show();                         }                     }                 });
            }); //登录框处理结束          });         </script>

Jquery Ajax 调用 WebService的更多相关文章

  1. Jquery ajax调用webservice总结

    jquery ajax调用webservice(C#)要注意的几个事项: 1.web.config里需要配置2个地方 <httpHandlers>      <remove verb ...

  2. Jquery AJAX 调用WebService服务

    对Jquery+JSON+WebService的一点认识 文章不错:http://www.cnblogs.com/tyb1222/archive/2011/10/13/2210549.html Jqu ...

  3. Ajax调用WebService

    前台代码: <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm1 ...

  4. Ajax调用WebService(一)

    Ajax调用WebService(一) http://www.cnblogs.com/leslies2/archive/2011/01/26/1934889.html 分类: Ajax 使用技术 We ...

  5. jquery ajax调用返回json格式数据处理

    Ajax请求默认的都是异步的 如果想同步 async设置为false就可以(默认是true) var html = $.ajax({ url: "some.php", async: ...

  6. WCF入门教程(四)通过Host代码方式来承载服务 一个WCF使用TCP协议进行通协的例子 jquery ajax调用WCF,采用System.ServiceModel.WebHttpBinding System.ServiceModel.WSHttpBinding协议 学习WCF笔记之二 无废话WCF入门教程一[什么是WCF]

    WCF入门教程(四)通过Host代码方式来承载服务 Posted on 2014-05-15 13:03 停留的风 阅读(7681) 评论(0) 编辑 收藏 WCF入门教程(四)通过Host代码方式来 ...

  7. ASP.NET实现二维码 ASP.Net上传文件 SQL基础语法 C# 动态创建数据库三(MySQL) Net Core 实现谷歌翻译ApI 免费版 C#发布和调试WebService ajax调用WebService实现数据库操作 C# 实体类转json数据过滤掉字段为null的字段

    ASP.NET实现二维码 using System;using System.Collections.Generic;using System.Drawing;using System.Linq;us ...

  8. Jquery Ajax调用aspx页面方法

    Jquery Ajax调用aspx页面方法 在asp.net webform开发中,用jQuery ajax传值一般有几种玩法 1)普通玩法:通过一般处理程序ashx进行处理: 2)高级玩法:通过as ...

  9. JQuery ajax调用asp.net的webMethod

    本文章转载:http://www.cnblogs.com/zengxiangzhan/archive/2011/01/16/1936938.html 在vs2010中,用JQuery ajax调用as ...

随机推荐

  1. JavaScript----Js操控-HTML5 &lt;progress&gt; 标签

    Js操控----HTML5 <progress> 标签 简单模拟下下载进度跑条 <h4>加载进度</h4> <input type="button& ...

  2. Mobile Web

    Silun来给大家介绍几个常见的移动浏览器标签~ 当当当~ <meta name="apple-mobile-web-app-capable" content="y ...

  3. 淘宝(阿里百川)手机客户端开发日记第六篇 Service详解(五)

    我们现在对上一节中的DEMO进行改进,在服务中开启线程来执行. package com.example.service; import android.app.Service; import andr ...

  4. JavaPersistenceWithHibernate第二版笔记-第五章-Mapping value types-007UserTypes的用法(@org.hibernate.annotations.Type、@org.hibernate.annotations.TypeDefs、CompositeUserType、DynamicParameterizedType、、、)

    一.结构 二.Hibernate支持的UserTypes接口  UserType —You can transform values by interacting with the plain JD ...

  5. Hibernate学习笔记(三)Hibernate生成表单ID主键生成策略

    一. Xml方式 <id>标签必须配置在<class>标签内第一个位置.由一个字段构成主键,如果是复杂主键<composite-id>标签 被映射的类必须定义对应数 ...

  6. 3D分析之3D要素工具箱(转)

    来自:http://blog.csdn.net/kikitamoon/article/details/8193764 整理有关 ArcGIS 10.1 3D分析工具箱中,3D Feature 工具箱中 ...

  7. 在 ASP.NET MVC 中使用 HTTPS (SSL/TLS)

    某些安全性较高的网页,如网上支付或用户登陆页面,可能会使用到https(SSL/TLS)来提高安全性.本文介绍了如何在ASP.NET MVC中强制某action使用https和如何进行向https页面 ...

  8. python连接mysql、oracle小例子

    import  MySQLdbimport  cx_Oracle   as  oraimport  pandas  as  pdfrom    sqlalchemy import create_eng ...

  9. [速成]了解一致性hash算法

    定义 一致性hash算法,在维基百科的定义是: Consistent hashing is a special kind of hashing such that when a hash table ...

  10. 压测过程中,获取不到redis连接池,发现redis连接数高

    说明:图片截得比较大,浏览器放大倍数看即可(涉及到隐私,打了码,请见谅,如果有疑问,欢迎骚扰). 最近在压测过程中,出现获取不到redis连接池的问题 xshell连接redis服务器,查看连接数,发 ...