首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > asp.net >

用户 'sa' 登录失败。 ,怎么改正

2012-04-12 
用户 sa 登录失败。请教高手,如何改正说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息

用户 'sa' 登录失败。 请教高手,如何改正
说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。 

异常详细信息: System.Data.SqlClient.SqlException: 用户 'sa' 登录失败。

源错误: 


行 85: {
行 86: SqlConnection myConn =GetConnection();
行 87: myConn.Open();
行 88: SqlDataAdapter adapt = new SqlDataAdapter(sqlStr, myConn);
行 89: DataSet ds = new DataSet();
 

源文件: F:\NewsIssue\App_Code\CommonClass.cs 行: 87 


下面是CommonClass.cs 代码
using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.Data.SqlClient;
namespace NewsIssue{

/// <summary>
/// CommonClass 的摘要说明
/// </summary>
public class CommonClass
{
public CommonClass()
{
//
// TODO: 在此处添加构造函数逻辑
//
}
  /// <summary>
  /// 连接数据库
  /// </summary>
  /// <returns>返回SqlConnection对象</returns>
  public SqlConnection GetConnection()
  {
  string myStr = ConfigurationManager.AppSettings["ConnectionString"].ToString();
  SqlConnection myConn = new SqlConnection(myStr);
  return myConn;
  }
  /// <summary>
  /// 说明:MessageBox用来在客户端弹出对话框。
  /// 参数:TxtMessage 对话框中显示的内容。
  /// 参数:Url 对话框关闭后,跳转的页
  /// </summary>
  public string MessageBox(string TxtMessage,string Url)
  {
  string str;
  str = "<script language=javascript>alert('" + TxtMessage + "');location='" + Url + "'</script>";
  return str;
  }
  /// <summary>
  /// 说明:MessageBox用来在客户端弹出对话框。
  /// 参数:TxtMessage 对话框中显示的内容。
  /// </summary>
  public string MessageBox(string TxtMessage)
  {
  string str;
  str = "<script language=javascript>alert('" + TxtMessage + "')</script>";
  return str;
  }
 
  /// <summary>
  /// 说明:ExecSQL用来执行SQL语句。
  ///返回值:操作是否成功(True\False)。
  ///参数:sqlStr SQL字符串
  /// </summary>
  public Boolean ExecSQL(string sqlStr)
  {
  // SqlConnection myConn = GetConnection();
  SqlConnection myConn = new SqlConnection("Data Source=wen-PC\\SA;Initial Catalog=db_news;Integrated Security=True");
  myConn.Open();
  SqlCommand myCmd = new SqlCommand(sqlStr, myConn);
  try
  {
  myCmd.ExecuteNonQuery();
  myConn.Close();
  }
  catch
  {
  myConn.Close();
  return false;
  }
  return true;
  }
  /// <summary>
  /// 说明:GetDataSet数据集,返回数据源的数据集
  ///返回值:数据集DataSet
  ///参数:sqlStr SQL字符串,TableName 数据表名称
  /// </summary>
  public System.Data.DataSet GetDataSet(string sqlStr, string TableName)
  {
  SqlConnection myConn =GetConnection();
  myConn.Open();
  SqlDataAdapter adapt = new SqlDataAdapter(sqlStr, myConn);
  DataSet ds = new DataSet();
  adapt.Fill(ds, TableName);
  myConn.Close();
  return ds;
  }


  /// <summary>
  /// 防止SQL 注入式攻击
  /// 
  /// </summary>
  /// <param name="loginName">用户登录名称</param>
  /// <param name="loginPwd">用户登录密码</param>
  public int checkLogin(string loginName, string loginPwd)
  {
  SqlConnection myConn = GetConnection();
  SqlCommand myCmd = new SqlCommand("select count(*) from tb_User where Name=@loginName and PassWord=@loginPwd", myConn);
  myCmd.Parameters.Add(new SqlParameter("@loginName", SqlDbType.VarChar, 20));
  myCmd.Parameters["@loginName"].Value = loginName;
  myCmd.Parameters.Add(new SqlParameter("@loginPwd", SqlDbType.VarChar, 50));
  myCmd.Parameters["@loginPwd"].Value = loginPwd;
  myConn.Open();
  int i = (int)myCmd.ExecuteScalar();
  myCmd.Dispose();
  myConn.Close();
  return i;
  }
  /// <summary>
  /// 实现随机验证码
  /// </summary>
  /// <param name="n">显示验证码的个数</param>
  /// <returns>返回生成的随机数</returns>
  public string RandomNum(int n) //
  {
  //定义一个包括数字、大写英文字母和小写英文字母的字符串
  string strchar = "0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P,Q,R,S,T,U,V,W,X,Y,Z,a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w,x,y,z";
  //将strchar字符串转化为数组
  //String.Split 方法返回包含此实例中的子字符串(由指定Char数组的元素分隔)的 String 数组。
  string[] VcArray = strchar.Split(',');
  string VNum = "";
  //记录上次随机数值,尽量避免产生几个一样的随机数  
  int temp = -1;  
  //采用一个简单的算法以保证生成随机数的不同
  Random rand = new Random();
  for (int i = 1; i < n + 1; i++)
  {
  if (temp != -1)
  {
  //unchecked 关键字用于取消整型算术运算和转换的溢出检查。
  //DateTime.Ticks 属性获取表示此实例的日期和时间的刻度数。
  rand = new Random(i * temp * unchecked((int)DateTime.Now.Ticks));
  }
  //Random.Next 方法返回一个小于所指定最大值的非负随机数。
  int t = rand.Next(61);
  if (temp != -1 && temp == t)
  { 
  return RandomNum(n);
  }
  temp = t;
  VNum += VcArray[t];
  }
  return VNum;//返回生成的随机数
  }

}
}

[解决办法]
先检测用户名和密码是否正确
检查是否有sa权限,现在2005+默认不允许使用sa用户登录,你需要开放这个角色,网上有步骤,自己去查
[解决办法]
SqlConnection myConn = new SqlConnection("Data Source=wen-PC\\SA;Initial Catalog=db_news;Integrated Security=True");
检查你的连接字符串,上面这个有问题
正常都是这种的
"Data Source=10.0.0.66;Initial Catalog=nsoff;Persist Security Info=True;User ID=sa;Password=123456;"
[解决办法]
在数据库中。。
右键PC-XXXX\SQLEXPRESS(SQL Server...)—>安全性—>"SQL Server和Windows身份证模式"

热点排行