我正在尝试在点击链接时生成excel文件,而不是在任何地方重定向。我把它变成了servlet但是当我尝试获取隐藏输入的值时,我得到一个空指针异常。我正在使用的代码是
JSP
<html:form action="/UploadExcel.do" enctype="multipart/form-data" method="post">
<a href="#" onclick="ExcelFiller.fill">Download Excel</a>
<input type="hidden" name="refBgcId" id="refBgcId" value="84"></input>
</html:form>
的Servlet
public class ExcelFiller extends HttpServlet {
private static final long serialVersionUID = 1L;
public void init(ServletConfig config) throws ServletException {
super.init(config);
}
public void destroy() {
}
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
System.out.println("Made it to the servlet");
doPost(request,response);
}
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
System.out.println("In doPost");
HttpSession session=(HttpSession) request.getSession(false);
String loggedInUserId = (String)session.getAttribute("strUserId");
try{
String referenceid = request.getParameter("refBgcId").toString();/*NULL POINTER EXCEPTION*/
ArrayList<String> details = new ArrayList<String>();
details = UploadBGCDAO.getDetails(referenceid);
createExcel(request,response,details, loggedInUserId);
} catch (Exception e) {
e.printStackTrace();
}
}
}
我已经尝试在本网站的类似问题的答案中找到解决方案,但我仍然无法完成这项工作。有人可以告诉我我做错了吗?
答案 0 :(得分:3)
仅当您提交表单时,输入参数才会传递给servlet,而不是在单击锚标记时。
如果要传递参数,请在查询字符串中附加参数。
答案 1 :(得分:1)
<form action="ExcelFiller.fill">
<input type="hidden" name="refBgcId" id="refBgcId" value="84"></input>
<input type="submit" value="Download Excel"></input>
</form>
并在servlet中进行以下更改。
属性的名称为refBgcId
。
改变陈述
String referenceid = request.getParameter("ref_id").toString();
到
String referenceid = request.getParameter("refBgcId").toString();
答案 2 :(得分:1)
您可以在Java Script中将URL中的参数传递为:
var refBgcId=84;
var url = "/UploadExcel.do?refBgcId="+refBgcId;
window.location.href =url;
在servlet中,您可以访问
String refBgcId= request.getParameter("refBgcId").toString();
答案 3 :(得分:0)
String referenceid = request.getParameter(&#34; refBgcId&#34;)。toString(); //这里refBgcId是一个名字......不要混淆jsp的名字和Id传递名称
然后在servlet中试试这个
String referenceid = request.getParameter(&#34; refBgcId&#34;)。toString();