1

ログイン画面を作ろうとしているので、ユーザからıbanNumberとpassを取得してデータベース上で確認しています。これは機能していますが、別のページで `doldur() を使用して、同じ ıbanNumber を持つデータベースに関する情報を取得しようとすると、null が返されます。

この状況を修正するにはどうすればよいですか? ibanNumber が null を返すのはなぜですか?

しない: 「Kullanici İslem Menusu.xhtml」ページの「hesap işlemleri」ボタンをクリックして jsf ページを追加し、「hesap işlemleri.xhtml」を開いて dataTable に入力します。

@ManagedBean(name = "login")

public class LoginBean {

public LoginBean() {

}
private String ıban_number;
private String sifre;
private String paraCek;
private String paraYatir;


public String getParaCek() {
    return paraCek;
}

public void setParaCek(String paraCek) {
    this.paraCek = paraCek;
}

public String getParaYatir() {
    return paraYatir;
}

public void setParaYatir(String paraYatir) {
    this.paraYatir = paraYatir;
}

public String getIban_number() {
    return ıban_number;
}

public void setIban_number(String ıban_number) {
    this.ıban_number = ıban_number;
}

public String getSifre() {
    return sifre;
}

public void setSifre(String sifre) {
    this.sifre = sifre;
}
db_connection dbLogin = new db_connection();
private PreparedStatement psLogin;
private ResultSet rsLogin;

public String getLogin() {


    try {

        System.out.println(getIban_number() + " " + getSifre());
        psLogin = dbLogin.getCon().prepareStatement("select * from kullanici_giris where ibanNumber=? and sifre=?");
        psLogin.setString(1, getIban_number());
        psLogin.setString(2, getSifre());
        System.out.println("Veri tabanına ulaşıldı");
        rsLogin = psLogin.executeQuery();

        while (rsLogin.next()) {
            return "true";

        }

    } catch (SQLException ex) {
        Logger.getLogger(LoginBean.class.getName()).log(Level.SEVERE, null, ex);
    }

    return "false";
}

public List<getAccountInfo> doldur() {

    System.out.println(getIban_number());
    List<getAccountInfo> liste = new ArrayList<getAccountInfo>();
    try {
        psLogin = dbLogin.getCon().prepareStatement("SELECT * FROM hesap_bilgi where ibanNumber = ? ");
        psLogin.setString(1, getIban_number());
        rsLogin = psLogin.executeQuery();


        while (rsLogin.next()) {
            getAccountInfo obj = new getAccountInfo();

            obj.setIbanNumber(rsLogin.getString(1));
            obj.setToplamButce(rsLogin.getString(2));
            obj.setHarcananButce(rsLogin.getString(3));
            obj.setKalanButce(rsLogin.getString(4));


            liste.add(obj);


        }
    } catch (SQLException ex) {
    }


    return liste;
}
}




    <?xml version='1.0' encoding='UTF-8' ?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"
      xmlns:h="http://java.sun.com/jsf/html">
    <h:head>
        <title>Kullanici İslem Menusu</title>
    </h:head>
    <h:body>
        <h:form>
            <h:panelGrid columns="1">

                <h:commandButton value="Hesap İşlemleri" action="hesap_islemleri"/>
                <h:commandButton value="Kişisel İşlemleri" action="kisisel_islemler"/>
                <h:commandButton value="Şubelerimiz" action="subelerimiz"/>
            </h:panelGrid>

        </h:form>
    </h:body>
</html>



<?xml version='1.0' encoding='UTF-8' ?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"
      xmlns:h="http://java.sun.com/jsf/html"
      xmlns:f="http://java.sun.com/jsf/core">
    <h:head>
        <title>Facelet Title</title>
    </h:head>
    <h:body>
        <h:form>


            <h:dataTable value="#{login.doldur()}" var="c">
                <h:column>
                    <f:facet name="header">
                        <h:outputLabel value="ıbanNumber"/>

                    </f:facet>
                    <h:outputLabel value="#{c.ibanNumber}"/>
                </h:column>

                <h:column>
                    <f:facet name="header">
                        <h:outputLabel value="ToplamButce"/>
                    </f:facet>
                    <h:outputLabel value="#{c.toplamButce}"/>
                </h:column>

                <h:column>
                    <f:facet name="header">
                        <h:outputLabel value="HarcananButce"/>
                    </f:facet>
                    <h:outputLabel value="#{c.harcananButce}"/>
                </h:column>

                <h:column>
                    <f:facet name="header">
                        <h:outputLabel value="KalanButce"/>
                    </f:facet>
                    <h:outputLabel value="#{c.kalanButce}"/>
                </h:column>
            </h:dataTable>

        </h:form>
    </h:body>
</html>
4

2 に答える 2

0

iBanNumber はユーザーから渡され、最初のページの実行時に初期化される Bean のインスタンスに格納されます。別のページから呼び出すと、マネージド Bean の新しいインスタンスが作成されます。おそらくそれが理由で、最初に Bean に設定した値が 2 回目には使用できなくなります。マネージド Bean のスコープを SessionScoped に変更してみてください。このようにして、Bean の値は、セッションの全期間にわたって保持されます。JSF セッションの詳細については、こちらを参照してください。

于 2013-05-23T17:47:51.600 に答える