不工作用户控件的功能无法在Sharepoint 2007列表Edit.aspx上工作

时间:2012-10-27 13:28:32

标签: asp.net sharepoint sharepoint-2010 sharepoint-2007 moss

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

empty user control

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>");

        }
    }
}

1 个答案:

答案 0 :(得分:0)

它首先看起来是一个数据问题。

要在生产框上进行调试,您可以使用remote debugger,或者您可以添加一个调用,检查是否返回了0项,产品是错误还是记录结果。