2010-08-30 3 views
0

Я пытаюсь получить некоторые значения из таблицы, используя источник данных в распорках, но это дает исключение:DataSource не работает в распорках

отчет Типа исключения

сообщение

описание Сервер обнаружил внутреннюю ошибку(), что помешало ему выполнить этот запрос.

исключение

javax.servlet.ServletException: java.lang.NullPointerException 
org.apache.struts.action.RequestProcessor.processException(RequestProcessor.java:520) 
org.apache.struts.action.RequestProcessor.processActionPerform(RequestProcessor.java:427) 
org.apache.struts.action.RequestProcessor.process(RequestProcessor.java:228) 
org.apache.struts.action.ActionServlet.process(ActionServlet.java:1913) 
org.apache.struts.action.ActionServlet.doPost(ActionServlet.java:462) 
javax.servlet.http.HttpServlet.service(HttpServlet.java:637) 
javax.servlet.http.HttpServlet.service(HttpServlet.java:717) 
org.netbeans.modules.web.monitor.server.MonitorFilter.doFilter(MonitorFilter.java:393) 


root cause 

java.lang.NullPointerException 
login.LoginAction.execute(LoginAction.java:31) 
org.apache.struts.action.RequestProcessor.processActionPerform(RequestProcessor.java:425) 
org.apache.struts.action.RequestProcessor.process(RequestProcessor.java:228) 
org.apache.struts.action.ActionServlet.process(ActionServlet.java:1913) 
org.apache.struts.action.ActionServlet.doPost(ActionServlet.java:462) 
javax.servlet.http.HttpServlet.service(HttpServlet.java:637) 
javax.servlet.http.HttpServlet.service(HttpServlet.java:717) 
org.netbeans.modules.web.monitor.server.MonitorFilter.doFilter(MonitorFilter.java:393) 

примечание Полный трассировки стека первопричины доступна в/6.0.26 журналах Apache Tomcat.

и мой распорки-config.xml находится содержит DataSources свойство соединения:

<form-beans> 
    <form-bean name="LoginForm" type="login.LoginForm"/> 
    <form-bean name="dynaActionForm" type="org.apache.struts.action.DynaActionForm"> 
     <form-property name="fname" type="java.lang.String"/> 
     <form-property name="lname" type="java.lang.String"/> 
    </form-bean> 
</form-beans> 
<data-sources> 
    <data-source key="dataSource" type="org.apache.tomcat.dbcp.dbcp.BasicDataSource"> 
     <set-property property="driverClassName" value="com.microsoft.sqlserver.jdbc.SQLServerDriver"/> 
     <set-property property="url" value="jdbc:sqlserver://192.168.1.169:1433;databaseName=localDB"/> 
     <set-property property="username" value="sa"/> 
     <set-property property="password" value="pass"/> 
    </data-source> 
</data-sources> 

<global-exceptions></global-exceptions> 

<global-forwards> 
    <forward name="welcome" path="/Welcome.do"/> 
</global-forwards> 

<action-mappings> 
    <action name="LoginForm" path="/login" scope="request" type="login.LoginAction" validate="false"> 
     <forward name="failure" path="/login.jsp"/> 
     <forward name="success" path="/WEB-INF/success.jsp"/> 
    </action> 

    <action name="dynaActionForm" path="/dyna" scope="request" type="DaynaAction.dynaActionClass" validate="false"> 
     <forward name="filure" path="/index.jsp"/> 
     <forward name="success" path="/WEB-INF/JSP/SuccessDyna.jsp"/> 
    </action> 

    <action path="/Welcome" forward="/welcomeStruts.jsp"/> 
</action-mappings> 

<controller processorClass="org.apache.struts.tiles.TilesRequestProcessor"/> 

<message-resources parameter="com/myapp/struts/ApplicationResource"/> 

<!-- ========================= Tiles plugin ===============================--> 
<!-- 
This plugin initialize Tiles definition factory. This later can takes some 
parameters explained here after. The plugin first read parameters from 
web.xml, thenoverload them with parameters defined here. All parameters 
are optional. 
The plugin should be declared in each struts-config file. 
- definitions-config: (optional) 
Specify configuration file names. There can be several comma 
separated file names (default: ??) 
- moduleAware: (optional - struts1.1) 
Specify if the Tiles definition factory is module aware. If true 
(default), there will be one factory for each Struts module. 
If false, there will be one common factory for all module. In this 
later case, it is still needed to declare one plugin per module. 
The factory will be initialized with parameters found in the first 
initialized plugin (generally the one associated with the default 
module). 
true : One factory per module. (default) 
false : one single shared factory for all modules 
- definitions-parser-validate: (optional) 
Specify if xml parser should validate the Tiles configuration file. 
true : validate. DTD should be specified in file header (default) 
false : no validation 

Paths found in Tiles definitions are relative to the main context. 
--> 
<plug-in className="org.apache.struts.tiles.TilesPlugin" > 
    <set-property property="definitions-config" value="/WEB-INF/tiles-defs.xml" /> 
    <set-property property="moduleAware" value="true" /> 
</plug-in> 

<!-- ========================= Validator plugin ================================= --> 
<plug-in className="org.apache.struts.validator.ValidatorPlugIn"> 
    <set-property 
     property="pathnames" 
     value="/WEB-INF/validator-rules.xml,/WEB-INF/validation.xml"/> 
</plug-in> 

ADN мой класс действий является

package login; 

import java.sql.Connection; 
import java.sql.PreparedStatement; 
import java.sql.ResultSet; 
import javax.servlet.http.HttpServletRequest; 
import javax.servlet.http.HttpServletResponse; 
import org.apache.struts.action.ActionForm; 
import org.apache.struts.action.ActionForward; 
import org.apache.struts.action.ActionMapping; 
import java.util.*; 
import javax.sql.DataSource; 

public class LoginAction extends org.apache.struts.action.Action { 

    /* forward name="success" path="" */ 
    private static final String SUCCESS = "success"; 
    private final static String FAILURE = "failure"; 
    private ResultSet rs; 
    private PreparedStatement ps; 
    private Connection conn; 

    @Override 
    public ActionForward execute(ActionMapping mapping, ActionForm form, HttpServletRequest request, HttpServletResponse response) 
      throws Exception { 
     LoginForm formBean = (LoginForm) form; 
     String fname = formBean.getName(); 
     String lname = formBean.getEmail(); 
     if ((fname == null) || lname == null) { 
      ArrayList al = new ArrayList(); 
      DataSource ds = (DataSource) servlet.getServletContext().getAttribute(""); 
      conn = ds.getConnection(); 
      String query = "select * from login"; 
      ps = conn.prepareStatement(query); 
      ResultSet rs = ps.executeQuery(); 
      int i = 1; 
      while (rs.next()) { 
       al.add(rs.getString(i)); 
       al.add(rs.getString(i + 1)); 
       i++; 
      } 
      request.setAttribute("value", al); 
      formBean.setError(); 
      return mapping.findForward(FAILURE); 
     } 
     return mapping.findForward(SUCCESS); 
    } 
} 

пожалуйста, любой один, чтобы помочь запустить выше программа .....

С уважением Mouli V

ответ

2

Ваш DataSource - null, что вызывает NullPointerException. И это null потому, что вы пытаетесь получить несуществующий атрибут:

DataSource ds = (DataSource) servlet.getServletContext().getAttribute(""); 

Оказывается, что в Struts вы получаете DataSource по телефону getDataSource(request)

Другое дело - вы пометили Struts2, но с использованием struts1. Вы уверены, что используете правильную библиотеку?

+0

как я могу назвать метод GetDataSource (запрос) в классе действий – Mouli

+0

HTTP: // распорки .apache.org/1.2.7/API/орг/Apache/распорки/действие/Action.html # GetDataSource% 28javax.servlet.http.HttpServletRequest,% 20java.lang.String% 29 – Bozho

0

Когда вы используете встроенную функцию источника данных Struts-1.X, struts-config.xml содержит все детали, связанные с БД. В этом случае вы можете использовать свойство validationQuery для проверки всего о db-соединении.

<data-sources> 
    <data-source key="datasource" type="org.apache.tomcat.dbcp.dbcp.BasicDataSource"> 
     <set-property property="password" value="pass" /> 
     <set-property property="username" value="uname" /> 
     <set-property property="driverClassName" value="oracle.jdbc.driver.OracleDriver" /> 
     <set-property property="url" value="jdbc:oracle:thin:@localhost:1521:abc" /> 
     <set-property property="validationQuery" value="select sysdate from dual" />  
    </data-source> 
</data-sources> 

Strtus инициализирует и обеспечивают Datasource и мы можем использовать его в любом классе действий в следующим образом:

public class LoginAction extends Action 
{ 
    public ActionForward execute(ActionMapping mapping, ActionForm form, HttpServletRequest request, HttpServletResponse response) 
    { 

     LoginForm loginForm = (LoginForm) form; 
     if (loginForm.getUsername() != null && loginForm.getPassword() != null) 
     { 

DataSource dataSource = getDataSource(request, "datasource"); 
Connection myConnection = dataSource.getConnection(); 
PreparedStatement stmt = null; 
String select = "SELECT USERNAME,PASSWORD from USER where USERNAME=?"; 
stmt = myConnection.prepareStatement(select); 
stmt.setString(1, username); 
rst = stmt.executeQuery(); 

................ 
} 
}   
Смежные вопросы