HTTP Status 500 - Ошибка при создании экземпляра класса сервлета com.Model
Я создал динамический веб-проект. У меня установлен Tomcat 6.0 для его запуска. Я пытаюсь создать веб-интерфейс с использованием DFC, и он будет подключаться к базам документов и выполнять какой-либо запрос. Когда я пытаюсь запустить этот код, я получаю указанную ниже ошибку. Так как я очень новичок в программировании DFC, любая помощь приветствуется. Благодарю.
welcome.jsp
<div class="w3ls_order w3ls_order1">
<Form method="post" action="Model">
<a class="popup-with-zoom-anim"><button class="button" type="submit">Generate</button></a>
</Form>
Model.java (сервлет)
package com;
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.xml.sax.SAXException;
import com.documentum.fc.common.DfException;
/**
* Servlet implementation class Model
*/
public class Model extends HttpServlet {
private static final long serialVersionUID = 1L;
/**
* Default constructor.
*/
public Model() {
// TODO Auto-generated constructor stub
}
/**
* @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
*/
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
}
/**
* @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
*/
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
System.out.println("All Good!");
}
public void docbase() throws SAXException, IOException
{
System.out.println("All good");
Connection con = new Connection();
try {
con.docBasecon();
} catch (DfException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
Connection.java
package com;
import java.io.File;
import java.io.IOException;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import org.w3c.dom.Document;
import org.w3c.dom.NodeList;
import org.w3c.dom.Node;
import org.w3c.dom.Element;
import org.xml.sax.SAXException;
import com.documentum.fc.common.DfException;
public class Connection {
public static void docBasecon() throws SAXException, IOException, DfException
{
File fXmlFile = new File("C:/Users/SAHAROM/workspace/License Utility/config.xml");
DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();
try {
DocumentBuilder dBuilder = dbFactory.newDocumentBuilder();
Document doc = dBuilder.parse(fXmlFile);
doc.getDocumentElement().normalize();
System.out.println("Root element :" + doc.getDocumentElement().getNodeName());
NodeList nList = doc.getElementsByTagName("docbase");
DocbaseConnection dbcon = new DocbaseConnection();
for (int temp = 0; temp < nList.getLength(); temp++)
{
Node nNode = nList.item(temp);
//System.out.println("\nCurrent Element :" + nNode.getNodeName());
if (nNode.getNodeType() == Node.ELEMENT_NODE)
{
Element eElement = (Element) nNode;
String docbaseName = eElement.getElementsByTagName("name").item(0).getTextContent();
String docbaseUname = eElement.getElementsByTagName("username").item(0).getTextContent();
String docbasePass = eElement.getElementsByTagName("password").item(0).getTextContent();
dbcon.DfcCon(docbaseName,docbaseUname,docbasePass);
}
}
} catch (ParserConfigurationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
DocbaseConnection.java
package com;
import com.documentum.fc.client.DfClient;
import com.documentum.fc.client.IDfClient;
import com.documentum.fc.client.IDfQuery;
import com.documentum.fc.client.IDfSession;
import com.documentum.fc.client.IDfSessionManager;
import com.documentum.fc.client.IDfSysObject;
import com.documentum.fc.common.DfException;
import com.documentum.fc.common.DfLoginInfo;
import com.documentum.fc.common.IDfLoginInfo;
import com.documentum.xml.xdql.DfXmlQuery;
import com.documentum.xml.xdql.IDfXmlQuery;
public class DocbaseConnection {
IDfSessionManager sessionMrg = null;
IDfSession session = null;
public void DfcCon(String docbaseName, String username,
String password) throws DfException {
System.out.println("\nResult" +docbaseName +username +password);
String Docbase = docbaseName;
IDfLoginInfo loginInfo = new DfLoginInfo();
loginInfo.setUser(username);
loginInfo.setPassword(password);
System.out.println("all good");
sessionMrg = DfClient.getLocalClient().newSessionManager();
System.out.println("all gooD");
sessionMrg.setIdentity(Docbase, loginInfo);
System.out.println("all gooD");
session = sessionMrg.getSession(Docbase);
System.out.println("All good");
String query = Getquery();
System.out.println("Query :" +query);
if(sessionMrg != null && session != null) {
sessionMrg.release(session);
}
}
public String Getquery()
{
String query = "select count(*) from dm_user";
return query;
}
}
Tomcat log
INFO: Marking servlet Model as unavailable
Sep 25, 2016 12:13:02 AM org.apache.catalina.core.StandardWrapperValve invoke
SEVERE: Allocate exception for servlet Model
java.lang.ClassNotFoundException: com.documentum.fc.common.DfException
at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1680)
at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1526)
at java.lang.Class.getDeclaredConstructors0(Native Method)
at java.lang.Class.privateGetDeclaredConstructors(Unknown Source)
at java.lang.Class.getConstructor0(Unknown Source)
at java.lang.Class.newInstance0(Unknown Source)
at java.lang.Class.newInstance(Unknown Source)
at org.apache.catalina.core.StandardWrapper.loadServlet(StandardWrapper.java:1149)
at org.apache.catalina.core.StandardWrapper.allocate(StandardWrapper.java:827)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:129)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:103)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:293)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:861)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:612)
at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:503)
at java.lang.Thread.run(Unknown Source)
Баночки
2 ответа
Решение
Мое приложение работает нормально сейчас. Мне пришлось поместить dfc.jar и dctm.jar в папку lib на tomcat.
В Connection.java у вас есть следующий метод:
public static void docBasecon() throws SAXException, IOException, DfException
DfException не был импортирован, следовательно, ошибка. Поэтому добавьте следующий оператор импорта в Connection.java:
import com.documentum.fc.common.DfException;