0

我正在使用下面的代码从数据库中获取文件并使用从下拉列表中填充的已安装打印机中选择的打印机打印它,我的问题是在使用Printjob.Start()期间它抛出异常系统找不到指定的文件

我的代码是,

protected void ggvqpdetail_RowCommand(object sender, GridViewCommandEventArgs e)
{
    if (e.CommandName.ToUpper().ToString() == "PRINTREC")
    {
        try
        {
            // Set the printer to a printer in the dropdown box when the selection changes. 
            PrintDocument printDoc = new PrintDocument();
            string a = TextBox1.Text + TextBox2.Text + TextBox3.Text;
            DataSet ds = ExamManagement.SP.Eval_QP_PrintSelect(a).GetDataSet();
            if (ddlprint.SelectedIndex != -1 && ds.Tables[0].Rows.Count > 0)
            {
                // The dropdown box's Text property returns the selected item's text, which is the printer name.
                printDoc.PrinterSettings.PrinterName = ddlprint.Text;

                Process printJob = new Process();
                printJob.StartInfo.FileName = ds.Tables[0].Rows[0]["Data"].ToString();
                printJob.StartInfo.UseShellExecute = true;
                printJob.StartInfo.Verb = "printto";
                printJob.StartInfo.CreateNoWindow = true;
                printJob.StartInfo.WindowStyle = ProcessWindowStyle.Hidden;
                printJob.StartInfo.Arguments = ddlprint.Text;
                printJob.StartInfo.WorkingDirectory = Path.GetDirectoryName(ds.Tables[0].Rows[0]["Data"].ToString());
                printJob.Start();
            }
        }
        catch(Exception ex)
        {
            Lblmsg.Visible = true;
            Lblmsg.Text = ex.Message;
        }
    }
}
4

1 回答 1

2

显然,问题取决于您实际放置在那个printJob.StartInfo.FileName. 该值来自数据库,因此唯一能够调查它的人是。查看您拥有的文件名,ds.Tables[0].Rows[0]["Data"]并确保该文件存在并且您可以在尝试打印的本地客户端上访问该文件。当然,这也揭示了您的解决方案的弱点,它似乎将文件名存储在数据库中,并期望该名称是每个客户端上的有效本地文件。不太可能是真的。

于 2013-05-28T09:37:00.070 回答