江湖急救啊,帮个忙!

AuC 2009-09-16 02:59:37
我用Ajax和Webservice 实现一个判断用户名是否存在的功能
前台页面我是这也写的
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
<title>无标题页</title>
<script src="JS/JScript.js" type="text/javascript"></script>
</head>
<body>
<form id="form1" runat="server">
<div>
用户名:<input id="txtName" type="text" runat="server" onblur="startRequest();" />
<div id="div1"></div>
</div>
</form>
</body>
</html>

在JS文件JScript.js中我是这样写的

var xmlHttp;
function createXMLHttpRequests()
{
if(window.ActiveXObject) //判断是否是IE浏览器
{
xmlHttp=new ActiveXObject("Microsoft.XMLHTTP");
}
else if (window.XMLHttpRequest)
{
xmlHttp=new XMLHttpRequest();
}
else
{
alert("该浏览器不支持AJAX,请更换浏览器");
}

}

function startRequest()
{
createXMLHttpRequests();
var name=document.getElementById("txtName").value;
alert(name);
xmlHttp.open("GET","WebService.asmx/CheckUserName?name="+name,true);
xmlHttp.onreadystatechange=function()
{
if(xmlHttp.readyState==4 && xmlHttp.status==200)
{
document.getElementById("div1").innerHTML=xmlHttp.responseText;
}
}
xmlHttp.send(null);
}

webservice里面的方法我是这样写的:
[WebMethod]
public string CheckUserName(string name)
{
string ss = "";
string sql = "select * from Business where BusiName='"+name+"'";
SqlConnection conn = new SqlConnection(DBHelper.connectionString);
conn.Open();
SqlCommand cmd = new SqlCommand(sql, conn);
object dd = cmd.ExecuteScalar();
int i = 0;
if (dd != null)
{
i = int.Parse(dd.ToString());
}

conn.Close();
if (i != 0)
{
ss = "该用户名可以使用";

}
else
{
ss = "不能使用";

}
return ss;
}

当鼠标移开文本框时判断是否有该用户名

我单独测试了webservice完全可以,但是当我用ajax调用的时候,我输入的用户名在数据库中存在,可老是显示:不能使用。。
可能是调用参数的问题,我始终找不到 原因,哪位大哥大姐帮帮忙啊!
...全文
172 14 打赏 收藏 转发到动态 举报
写回复
用AI写文章
14 条回复
切换为时间正序
请发表友善的回复…
发表回复
wszhoho 2009-09-16
  • 打赏
  • 举报
回复
得分贴牛头不对马嘴,js发送请求居然用HttpUtility.UrlEncode,您真是高手。
zjybushiren88888 2009-09-16
  • 打赏
  • 举报
回复
编码保持一致
AuC 2009-09-16
  • 打赏
  • 举报
回复
原来是编码的问题,谢谢了!100分送给你!
ncjcz 2009-09-16
  • 打赏
  • 举报
回复
中文,URL编码问题?
System.Web.HttpUtility.UrlEncode(NAME)
wangying110166 2009-09-16
  • 打赏
  • 举报
回复
输入的用户名在数据库中存在,可老是显示:不能使用。。
已经存在了,当然不能用了
LutzMark 2009-09-16
  • 打赏
  • 举报
回复
调式一下看看dd是不是为null
AuC 2009-09-16
  • 打赏
  • 举报
回复
应该不是URL的问题,因为从方法里面可以返回值了,只是传入的参数有问题!
leon28 2009-09-16
  • 打赏
  • 举报
回复
[Quote=引用 4 楼 yuxuanji 的回复:]
xmlHttp.open("GET","WebService.asmx/CheckUserName?name="+name,true);
url问题
[/Quote]
http://
AuC 2009-09-16
  • 打赏
  • 举报
回复
不管数据库里面有没有都是不能使用!
wszhoho 2009-09-16
  • 打赏
  • 举报
回复
ExecuteScalar是返回第一列,你跟踪进去看下i是几。

建议:
1
var name=document.getElementById("txtName").value;
这句,最好加上url编码 var name=escape(document.getElementById("txtName").value);
在webservice端用Server.UrlDecode解码,这样可以保证中文用户名不出错。

2
string sql = "select * from Business where BusiName='"+name+"'";
这句绝对会被注入,用sql参数查询吧。
LutzMark 2009-09-16
  • 打赏
  • 举报
回复
xmlHttp.open("GET","WebService.asmx/CheckUserName?name="+name,true);
url问题
ncjcz 2009-09-16
  • 打赏
  • 举报
回复
输入的用户名在数据库中存在,可老是显示:不能使用。。
已经存在了,当然不能用了
jerry_zuo 2009-09-16
  • 打赏
  • 举报
回复
调试的 public string CheckUserName(string name) 这个name 有值吗? 应该没有吧?
你这个 需要托一个scriptmanage 控件~~~
zhulong1111 2009-09-16
  • 打赏
  • 举报
回复
mark

62,046

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧