我在asp.net中有一个非常新的功能,正在寻求您的帮助,我正在尝试使用新用户的数据上传图像,以便可以在数据库中成功添加用户信息。但是现在我一直坚持上传图片。我的表单可以完美地将所有数据传递给 action ,所以我从那里开始:
public ActionResult SaveUser(string oid, string fname, string uname, string pass, string pass2, string bt, HttpPostedFileBase image)
{
string iuser = Session["UserID"].ToString();
string fileName = Path.GetFileName(image.FileName);
String fileExtension = Path.GetExtension(fileName);
int fileSize = image.ContentLength;
if (fileExtension.ToLower() == ".jpg" || fileExtension.ToLower() == ".jpeg")
{
Stream stream = image.InputStream;
BinaryReader binaryReader = new BinaryReader(stream);
byte[] bytes = binaryReader.ReadBytes((int)stream.Length);
}
if (pass == pass2)
{
if (bt == "0")
{
string packge = "tflhr.pro_new_user.insert_data";
ds = new DataSet();
ds = _clsDataAccess.package_user(packge, fname, uname, pass, iuser );
}
}
return RedirectToAction("User", new { cpid = 0, bt = 0 });
}
现在在包含图像的动作 image 中,我如何在数据库中上传图像数据是我的连接:
public DataSet package_user(string package, string fname, string pass, string uname, byte[] bytes, string iuser)
{
conn = new OracleConnection(clsConnection.ConnectionSave);
conn.Open();
cmd = new OracleCommand(package, conn);
cmd.CommandType = CommandType.StoredProcedure;
cmd.Parameters.Add("cur_c1", OracleType.Cursor).Direction = ParameterDirection.Output;
cmd.Parameters.Add("user_name", OracleType.VarChar).Value = fname;
cmd.Parameters.Add("user_pass", OracleType.VarChar).Value = pass;
cmd.Parameters.Add("user_enid", OracleType.VarChar).Value = uname;
cmd.Parameters.Add("user_name", OracleType.Blob).Value = bytes;
cmd.Parameters.Add("iuser", OracleType.VarChar).Value = iuser;
cmd.Parameters.Add("euser", OracleType.VarChar).Value = iuser;
oda = new OracleDataAdapter(cmd);
ds = new DataSet();
conn.Close();
oda.Fill(ds);
return ds;
}
和存储过程为:
CREATE OR REPLACE PACKAGE BODY TFLHR.pro_new_user as
procedure insert_data (cur_c1 out t_cursor, user_name in varchar2, user_pass in varchar2,
user_enid in varchar2, bytes in blob, iuser in varchar2, euser in varchar2)
is
code varchar2(5);
begin
select nvl(max(to_number(user_text)),0)+1 into code from tflhr.t_user;
insert into tflhr.t_user (oid, user_text, user_name, user_pass, user_enid,image, iuser, euser,user_path)
values
('USERx'||lpad(code,5,'0'), lpad(code,5,'0'), user_name, user_pass, user_enid, bytes, iuser, euser, lpad(code,5,'0'));
open cur_c1 for
select '1' from dual;
commit;
end insert_data;
end;
/
我遇到了异常
Exception Image 我如何更改此参数以上传图像。请帮助我,如果有任何错误,请短路。谢谢
答案 0 :(得分:0)
出现异常列表中命名参数的多个实例的原因是,您要添加两次相同的参数名称(如本代码段所示)(并且参数名称也与参数数据类型相对应):
cmd.Parameters.Add("user_name", OracleType.VarChar).Value = fname;
cmd.Parameters.Add("user_pass", OracleType.VarChar).Value = pass;
cmd.Parameters.Add("user_enid", OracleType.VarChar).Value = uname;
// user_name parameter used twice here, the exception thrown
cmd.Parameters.Add("user_name", OracleType.Blob).Value = bytes;
您应该改为添加bytes
参数名称:
cmd.Parameters.Add("cur_c1", OracleType.Cursor).Direction = ParameterDirection.Output;
cmd.Parameters.Add("user_name", OracleType.VarChar).Value = fname;
cmd.Parameters.Add("user_pass", OracleType.VarChar).Value = pass;
cmd.Parameters.Add("user_enid", OracleType.VarChar).Value = uname;
cmd.Parameters.Add("bytes", OracleType.Blob).Value = bytes; // problem fixed
cmd.Parameters.Add("iuser", OracleType.VarChar).Value = iuser;
cmd.Parameters.Add("euser", OracleType.VarChar).Value = iuser;
请注意,您可以使用AddWithValue
简化参数定义,但要确保使用正确的数据类型传递参数。
此外,您应该以正确的顺序传递方法参数:
ds = _clsDataAccess.package_user(packge, fname, pass, uname, bytes, iuser);
因为方法签名看起来像这样:
public DataSet package_user(string package, string fname, string pass, string uname, byte[] bytes, string iuser)