帮忙把错误改一下!
using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
using System.Configuration;
using System.Data.SqlClient;
namespace eshop.pagemodel.model1
{
/// <summary>
/// showWareByType 的摘要说明。
/// </summary>
public class showWareByType : System.Web.UI.Page
{
protected System.Web.UI.WebControls.DataList dl_BookByType;
protected static char typeID;
protected static string strConn= ConfigurationSettings.AppSettings ["strConnection"];
private void Page_Load(object sender, System.EventArgs e)
{
// 在此处放置用户代码以初始化页面
//WareType字段在数据库里的值为“牛奶”“香蕉”等之类的汉字。
ViewState["wareTypeID"]=Request.QueryString["WareType"];
dl_BookByType.DataSource=GetWareMessage(char.Parse(ViewState["wareTypeID"].ToString()));
dl_BookByType.DataBind();
}
#region Web 窗体设计器生成的代码
override protected void OnInit(EventArgs e)
{
//
// CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}
/// <summary>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
/// </summary>
private void InitializeComponent()
{
this.Load += new System.EventHandler(this.Page_Load);
}
#endregion
public SqlDataReader GetWareMessage(char wareTypeID)
{
string strSQL;
SqlDataReader result;
SqlConnection myCn;
SqlCommand myCm;
try
{
myCn=new SqlConnection(strConn);
strSQL="select * from Ware where Ware_ChildType="+wareTypeID;
myCm=new SqlCommand(strSQL,myCn);
myCn.Open ();
result=myCm.ExecuteReader(CommandBehavior.CloseConnection);
return result;
}
catch(System.Data.SqlClient.SqlException er)
{
throw new Exception(er.Message);
}
}
}
}
这里报错:
字符串的长度只能为一个字符。
说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。
异常详细信息: System.FormatException: 字符串的长度只能为一个字符。
源错误:
行 32: ViewState["wareTypeID"]=Request.QueryString["WareType"];
行 33:
行 34: dl_BookByType.DataSource=GetWareMessage(char.Parse(ViewState["wareTypeID"].ToString()));
行 35: dl_BookByType.DataBind();
行 36: /*try
源文件: e:\eshop\pagemodel\model1\showwarebytype.aspx.cs 行: 34
堆栈跟踪:
[FormatException: 字符串的长度只能为一个字符。]
System.Char.Parse(String s) +116
eshop.pagemodel.model1.showWareByType.Page_Load(Object sender, EventArgs e) in e:\eshop\pagemodel\model1\showwarebytype.aspx.cs:34
System.Web.UI.Control.OnLoad(EventArgs e) +67
System.Web.UI.Control.LoadRecursive() +35
System.Web.UI.Page.ProcessRequestMain() +731