0

我在 sharepoint 2007 列表 Edit.aspx 页面上部署了一个用户控件。它在我的测试服务器上运行良好,但在生产中只加载了用户控件的 UI。页面加载时没有文本框或组合框被填充。请查看用户控件默认值的屏幕截图,而不是填写的数据。还可以找到下面的代码,它从查询字符串中获取 ID 并在页面加载时加载所需的数据。我使用 createdby value 来检查谁在分配列表项。如果用户正在访问不是由他创建的数据,则将其重定向到其他页面。请指导我。我应该做什么或检查以使其工作。

空的用户控件

public partial class Class1 : System.Web.UI.UserControl
{

    static string name, lname, Number;  

    protected void Page_Load(object sender, EventArgs e)
    {
        try
        {
            string c1,c2,c3,c4,c5, Created;
            if (!Page.IsPostBack)
            {

                     EditID = Convert.ToInt32(Request.QueryString["ID"]);
                     name = SPContext.Current.Web.CurrentUser.Name;
                     lname = SPContext.Current.Web.CurrentUser.LoginName;

                SPSecurity.RunWithElevatedPrivileges(delegate()
             {
                 using (SPSite site = new SPSite("site name"))
                 {
                     using (SPWeb web = site.OpenWeb())
                     {
                         SPList list = web.Lists["list1"];
                         SPList UserSkill = web.Lists["list2"]; 
                         ItemForEdit = UserSkill.GetItemById(EditID);
                         c1 = ItemForEdit["col1"].ToString();
                         c2 = ItemForEdit["col2"].ToString();
                         c3 = ItemForEdit["col3"].ToString();
                         c4 = ItemForEdit["col4"].ToString();
                         c5 = ItemForEdit["col5"].ToString();
                         Created = ItemForEdit["Author"].ToString();
                         Number = ItemForEdit["col6"].ToString();
                         string[] extract;
                         extract = Created.Split('#');
                         if (name == extract[1])
                         {

                             WholeData = web.Lists["list1"].Items.GetDataTable(); 
                             Roles = WholeData.DefaultView.ToTable(true, "Title");
                             txtnumber.Text = Number;
                             ddlRole.DataSource = Roles;
                             ddlRole.DataTextField = "Title";
                             ddlRole.DataValueField = "Title";
                             ddlRole.DataBind();
                             ddlRole.SelectedValue = c1;

            //more code

            }
                         else
                         {
                             Response.Redirect("/IM/pages/Intrusion.aspx", false);
                         }
                     }
                 }
             });

            }
        }
        catch (Exception exc)
        {
            HttpContext.Current.Response.Write("<script>alert('Exception on page load: " + exc.Message + "')</script>");

        }
    }
}
4

1 回答 1

0

乍一看,它看起来是一个数据问题。

要在您的生产机器上进行调试,您可以使用远程调试器,或者您可以添加一个调用来检查是否返回了 0 个项目并生成错误或记录结果。

于 2012-10-28T21:13:41.253 回答