Object reference not set to an instance of an object

mercoledì 02 dicembre 2015 - 17.07

adachigahara Profilo | Newbie

salve a tutti, spero che mi possiate dare una mano.. ho questo codice:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Data;
using System.Data.OracleClient;
using System.Configuration;
using System.Drawing;

namespace Logistica.DPI
{
public partial class assegnaDPI : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
if (Session["username"] == null)
Response.Redirect("~/Account/Login.aspx?msg=Sessione Scaduta. Ripetere il Login!");
if (!IsPostBack)
{
ddlqualifica.DataSource = ManagerUser.getQualifiche(0, "", "nome", "asc");
ddlqualifica.DataTextField = "nome";
ddlqualifica.DataValueField = "nome";
ddlqualifica.DataBind();
ddlqualifica.Items.Insert(0, new ListItem("", ""));
ddlqualifica.Items.Insert(1, "Altro");
ddlqualifica.Items.Insert(2, "Coperta");
ddlqualifica.Items.Insert(3, "Macchina");
DataTable dt = ManagerUser.GetAllUser(0, txtcognome.Text, txtnome.Text, txtmatricola.Text, txtmercantile.Text, ddlqualifica.SelectedValue, "", "", "", "", "", "", "", "", "", (Session["tipodpi"].ToString().Equals("1") ? "1" : ""), "", (Session["tipodpi"].ToString().Equals("2") ? "1" : ""), (Session["tipodpi"].ToString().Equals("3") ? "1" : ""),"","", "cognome", "asc");
for (int i = 0; i < dt.Rows.Count; i++)
{
ddlutenti.Items.Add(new ListItem(dt.Rows[i]["cognome"] + " " + dt.Rows[i]["nome"] + "-" + dt.Rows[i]["matricola"] + " " + dt.Rows[i]["qualifica"], dt.Rows[i]["id_utente"].ToString()));
}
ddlutenti.Items.Insert(0, new ListItem("", ""));
if (!Session["dpi"].ToString().Equals("2") && !Session["mdpimes"].ToString().Equals("1") && !Session["mdpivsg"].ToString().Equals("1"))
Bassegna.Enabled = false;
}
}

protected void Button1_Click(object sender, EventArgs e)
{
lblsezione.Visible = false;
lblsezionevalore.Visible = false;
lblqualifica.Visible = false;
lblaualificavalore.Visible = false;
lblerror.Visible = false;
griglia.Visible = false;
Bassegna.Visible = false;
ddlutenti.Items.Clear();
DataTable dt = ManagerUser.GetAllUser(0, txtcognome.Text, txtnome.Text, txtmatricola.Text, txtmercantile.Text, ddlqualifica.SelectedValue, "", "", "", "", "", "", "", "", "", (Session["tipodpi"].ToString().Equals("1") ? "1" : ""), "",(Session["tipodpi"].ToString().Equals("2")?"1":""),(Session["tipodpi"].ToString().Equals("3")?"1":""),"","", "cognome", "asc");
for (int i = 0; i < dt.Rows.Count; i++)
{
ddlutenti.Items.Add(new ListItem(dt.Rows[i]["cognome"] + " " + dt.Rows[i]["nome"] + "-" + dt.Rows[i]["matricola"] + " " + dt.Rows[i]["qualifica"], dt.Rows[i]["id_utente"].ToString()));
}
ddlutenti.Items.Insert(0, new ListItem("", ""));
}

protected void ddlutenti_SelectedIndexChanged(object sender, EventArgs e)
{
lblsezione.Visible = true;
lblsezionevalore.Visible = true;
lblqualifica.Visible = true;
lblaualificavalore.Visible = true;
lblerror.Visible = false;
int id = 0;
try
{
id = Convert.ToInt32(ddlutenti.SelectedValue);
}
catch (Exception)
{ }
DataTable dt = ManagerUser.GetAllUser(id, txtcognome.Text, txtnome.Text, txtmatricola.Text, txtmercantile.Text, ddlqualifica.SelectedValue, "", "", "", "", "", "", "", "", "", (Session["tipodpi"].ToString().Equals("1") ? "1" : ""), "", (Session["tipodpi"].ToString().Equals("2") ? "1" : ""), (Session["tipodpi"].ToString().Equals("3") ? "1" : ""),"","", "cognome", "asc");
lblaualificavalore.Text = dt.Rows[0]["qualifica"].ToString();
lblsezionevalore.Text = dt.Rows[0]["sezione"].ToString();
Translate tt = new Translate();
griglia.Columns[0].HeaderText = tt.TranslateTXT("//Resource/item[@name='cnome']");
griglia.Columns[1].HeaderText = tt.TranslateTXT("//Resource/item[@name='misura']");
griglia.Columns[2].HeaderText = tt.TranslateTXT("//Resource/item[@name='partecorpo']");
griglia.Columns[3].HeaderText = tt.TranslateTXT("//Resource/item[@name='quantita']");
griglia.Columns[4].HeaderText = tt.TranslateTXT("//Resource/item[@name='dataconsegna']");
griglia.Columns[5].HeaderText = tt.TranslateTXT("//Resource/item[@name='datascadenza']");
griglia.Columns[6].HeaderText = tt.TranslateTXT("//Resource/item[@name='destinatari']");
griglia.DataSource = ManagerDPI.getDPISpettanti(dt.Rows[0]["sezione"].ToString(), dt.Rows[0]["qualifica"].ToString(),Session["tipodpi"].ToString());
griglia.DataBind();


griglia.Visible = true;
Bassegna.Visible = true;
Bassegna.Enabled = true;
}

protected void griglia_RowDataBound(object sender, GridViewRowEventArgs e)
{
if (e.Row.RowType == DataControlRowType.DataRow)
{
DropDownList ddl = (DropDownList)e.Row.FindControl("ddlmisura");
DataTable dt = ManagerDPI.getDPIinMagazzino(0, Convert.ToInt32(griglia.DataKeys[e.Row.RowIndex].Value), "", "",Session["tipodpi"].ToString(), "descrizione", "asc");
for (int i = 0; i < dt.Rows.Count; i++)
{
if (Convert.ToInt32(dt.Rows[i]["quantita"].ToString()) > 0)
ddl.Items.Add(new ListItem(dt.Rows[i]["descrizione"].ToString(), dt.Rows[i]["id"].ToString()));
}
if (ddl.Items.Count > 0)
{
ddl.Items.Insert(0, new ListItem("", ""));
ddl.Enabled = true;
TextBox tb = (TextBox)e.Row.FindControl("txtdataconsegna");
tb.Enabled = true;
tb.Text = DateTime.Now.ToString("dd/MM/yyyy");
tb = (TextBox)e.Row.FindControl("txtdatascadenza");
tb.Enabled = true;
tb = (TextBox)e.Row.FindControl("txtquantita");
tb.Enabled = true;
}
else
{
ddl.Items.Insert(0, new ListItem("N/A", ""));
ddl.Enabled = false;
TextBox tb = (TextBox)e.Row.FindControl("txtdataconsegna");
tb.Enabled = false;
tb = (TextBox)e.Row.FindControl("txtdatascadenza");
tb.Enabled = false;
tb = (TextBox)e.Row.FindControl("txtquantita");
tb.Enabled = false;
}
}
}

protected void Bassegna_Click(object sender, EventArgs e)
{
bool esito = false;
OracleConnection connection = new OracleConnection(ConfigurationManager.ConnectionStrings["ConnectionString"].ToString());
connection.Open();
OracleTransaction tran = connection.BeginTransaction();
esito = ManagerDPI.aggiornaDPIcorrenti(connection, tran, Convert.ToInt32(ddlutenti.SelectedValue));
if (esito)
{
int contatore = 0;
for (int i = 0; i < griglia.Rows.Count; i++)
{
DropDownList ddl = (DropDownList)griglia.Rows[i].FindControl("ddlmisura");
TextBox quantita = (TextBox)griglia.Rows[i].FindControl("txtquantita");
TextBox data_consegna = (TextBox)griglia.Rows[i].FindControl("txtdataconsegna");
TextBox data_scadenza = (TextBox)griglia.Rows[i].FindControl("txtdatascadenza");
if (ddl.Enabled && ddl.SelectedIndex>0)
{
if (!quantita.Text.Equals("0"))
{
esito = ManagerDPI.assegnaDPI(connection, tran, Convert.ToInt32(ddlutenti.SelectedValue), Convert.ToInt32(griglia.DataKeys[i].Value), Convert.ToInt32(ddl.SelectedValue), "", data_consegna.Text, data_scadenza.Text, Convert.ToInt32(quantita.Text));
if (!esito)
{
Llblerror.Key= "erroreassegnadpi";
lblerror.ForeColor = Color.Red;
lblerror.Visible = true;
tran.Rollback();
connection.Close();
return;
}
contatore++;
}
}

}
if (contatore > 0)
{
Llblerror.Key = "assegnazionedpi";
lblerror.ForeColor = Color.Green;
lblerror.Visible = true;
tran.Commit();
connection.Close();
OpenNewWindow("PDFReportDPIUtente.aspx?id_utente=" + ddlutenti.SelectedValue + "&corrente=1&dal=&al=&dal1=&al1=&sortExp=&sortDir=");
Bassegna.Enabled = false;
}
else
{
Llblerror.Key = "nodpiselected";
lblerror.ForeColor = Color.Red;
lblerror.Visible = true;
tran.Rollback();
connection.Close();
}
}
else
{
Llblerror.Key = "erroreassegnadpi";
lblerror.ForeColor = Color.Red;
lblerror.Visible = true;
tran.Rollback();
connection.Close();
}
}
public void OpenNewWindow(string url)
{
ClientScript.RegisterStartupScript(this.GetType(), "newWindow", String.Format("<script>window.open('{0}');</script>", url));
}

}
}

come errore mi dice :

Object reference not set to an instance of an object

Spero che qualcuno mi dia una mano.

Gluck74 Profilo | Guru

Magari specifica dove, come e quando hai il messaggio di errore!!!!!!!!!!!!!!!!!!!!!!!!!!!
____________
http://glucolo.wordpress.com
Ricordati di utilizzare il tasto "Accetta" se i nostri consigli ti sono serviti a risolvere il problema.
È il modo per ringraziare chi ti ha aiutato.
Partecipa anche tu! Registrati!
Hai bisogno di aiuto ?
Perchè non ti registri subito?

Dopo esserti registrato potrai chiedere
aiuto sul nostro Forum oppure aiutare gli altri

Consulta le Stanze disponibili.

Registrati ora !
Copyright © dotNetHell.it 2002-2024
Running on Windows Server 2008 R2 Standard, SQL Server 2012 & ASP.NET 3.5