- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
这是我第一次使用 .jsp 和 Netbeans。我正在尝试创建一个利用 fullcalendar 的系统,用户可以选择月/年对并显示谁在所选月份的哪一天休假。基本上,它不会列出事件,而是列出缺席的员工姓名。我将这些名称称为事件。
这里的问题是日历没有显示任何事件。我关注了this tutorial和 this question (指的是我链接的教程)但我似乎无法让它工作。日历在那里,但没有事件。我可以通过单击日历或编辑 .jsp 内的数组来手动添加事件,但我希望它从数据库生成事件。
这是我的代码:
main.jsp
<form name="choose" method="POST">
<table class="centerTable">
<tr>
<td>Month</td>
<td>:</td>
<td>
<select name="month" style="width:130px" required>
<option value="">Select a month:</option>
<option value="${01}" ${param.month == 01 ? 'selected' : ''}>January</option>
<option value="${02}" ${param.month == 02 ? 'selected' : ''}>February</option>
<option value="${03}" ${param.month == 03 ? 'selected' : ''}>March</option>
<option value="${04}" ${param.month == 04 ? 'selected' : ''}>April</option>
<option value="${05}" ${param.month == 05 ? 'selected' : ''}>May</option>
<option value="${06}" ${param.month == 06 ? 'selected' : ''}>June</option>
<option value="${07}" ${param.month == 07 ? 'selected' : ''}>July</option>
<option value="${08}" ${param.month == 08 ? 'selected' : ''}>August</option>
<option value="${09}" ${param.month == 09 ? 'selected' : ''}>September</option>
<option value="${10}" ${param.month == 10 ? 'selected' : ''}>October</option>
<option value="${11}" ${param.month == 11 ? 'selected' : ''}>November</option>
<option value="${12}" ${param.month == 12 ? 'selected' : ''}>December</option>
</select>
</td>
</tr>
<tr>
<td>Year</td>
<td>:</td>
<td>
<select name="year" style="width:130px" required>
<option value="">Select a year:</option>
<option value="${2016}" ${param.year == '2016' ? 'selected' : ''}>2016</option>
<option value="${2015}" ${param.year == '2015' ? 'selected' : ''}>2015</option>
<option value="${2014}" ${param.year == '2014' ? 'selected' : ''}>2014</option>
<option value="${2013}" ${param.year == '2013' ? 'selected' : ''}>2013</option>
<option value="${2012}" ${param.year == '2012' ? 'selected' : ''}>2012</option>
</select>
</td>
</tr>
<tr>
<td colspan=3 align=center>
<input type="submit" name="submit" value="Submit" onChange="submit();return false;">
</td>
</tr>
</table>
</form>
<script>
var y = "${param.year}";
var m = "${param.month}";
$(document).ready(function() {
$('#calendar').fullCalendar({
selectable: true,
selectHelper: true,
select: function(start, end) {
var title = prompt('Event Title:');
var eventData;
if (title) {
eventData = {
title: title,
start: start,
end: end
};
$('#calendar').fullCalendar('renderEvent', eventData, true);
}
$('#calendar').fullCalendar('unselect');
},
editable: true,
eventLimit: true,
events: "/Leave/KServlet"
});
if (y === "" || m === "")
$('#calendar').fullCalendar('today');
else
$('#calendar').fullCalendar('gotoDate', (y+'-'+m));
});
</script>
<div id="calendar"></div>
KServlet.java
public class KServlet extends HttpServlet
{
Calendar now = Calendar.getInstance();
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException
{
List l = new ArrayList();
try {
Connection con = null;
con = DriverManager.getConnection("jdbc:derby://localhost:1527/C:\\Users\\Acer\\Desktop\\livedb?username=username&password=password");
int month, year;
if (request.getParameter("month").equals(""))
month = now.get(Calendar.MONTH) + 1;
else
month = Integer.parseInt(request.getParameter("month"));
if (request.getParameter("year").equals(""))
year = now.get(Calendar.YEAR);
else
year = Integer.parseInt(request.getParameter("year"));
Statement stmt = null;
String query = "select PERSON_NAME, TYPE_CODE, FROM_DATE, TO_DATE " +
"from LV_INFO_VIEW " +
"where YEAR(FROM_DATE) = " + year + " and MONTH(FROM_DATE) = " + month;
stmt = con.createStatement();
ResultSet rs = stmt.executeQuery(query);
while (rs.next()) {
CalendarDTO c = new CalendarDTO();
c.setTitle(rs.getString("PERSON_NAME"));
c.setStart(rs.getString("FROM_DATE"));
c.setEnd(rs.getString("TO_DATE"));
String t = rs.getString("TYPE_CODE");
if (t.equalsIgnoreCase("ANNUAL") || t.equalsIgnoreCase("AL - CT"))
{
c.setColor("green");
c.setTextColor("white");
}
else if (t.equalsIgnoreCase("MEDICAL") || t.equalsIgnoreCase("ML-CT"))
{
c.setColor("red");
c.setTextColor("white");
}
else if (t.equalsIgnoreCase("MARRIAGE"))
{
c.setColor("#ff6699");
c.setTextColor("black");
}
else if (t.equalsIgnoreCase("MATERNITY") || t.equalsIgnoreCase("PATERNITY"))
{
c.setColor("#b2e7d3");
c.setTextColor("black");
}
else if (t.equalsIgnoreCase("UNPAID"))
{
c.setColor("blue");
c.setTextColor("white");
}
else if (t.equalsIgnoreCase("COMPASSIONATE") || t.equalsIgnoreCase("DOF"))
{
c.setColor("black");
c.setTextColor("white");
}
else if (t.equalsIgnoreCase("REPLACEMENT"))
{
c.setColor("#720045");
c.setTextColor("white");
}
else if (t.equalsIgnoreCase("HOSPITAL") || t.equalsIgnoreCase("SICK"))
{
c.setColor("#7a0000");
c.setTextColor("white");
}
else if (t.equalsIgnoreCase("EMERGENCY"))
{
c.setColor("yellow");
c.setTextColor("black");
}
else
{
c.setColor("#ffd4b1");
c.setTextColor("black");
}
l.add(c);
}
}
catch (SQLException ex) { Logger.getLogger(KServlet.class.getName()).log(Level.SEVERE, null, ex); }
response.setContentType("application/json");
response.setCharacterEncoding("UTF-8");
PrintWriter out = response.getWriter();
out.write(new Gson().toJson(l));
}
}
还有 CalendarDTO 类。它包含标题、开始、结束、颜色和文本颜色。所有变量都是字符串,并且有各自的 setter 和 getter。
servlet 在 web.xml 中正确映射,并且 Netbeans 不会输出任何错误。
但是,从 Chrome 控制台我可以看到 KServlet 返回了一个只有“[]”的空白页面。我猜我弄乱了 servlet 中的某些内容,但我不确定是什么。
我真的很感谢任何可以提供帮助的人。
最佳答案
多亏了 Arvind 和飓风,我现在设法让它工作了。除了错误的 SQL 语句之外,还有 javascript 导入和不合适的数据类型(String 而不是 int)的安排导致了问题。
我已经编辑了我的脚本,以防有人想用它作为指南
关于javascript - 通过 servlet 将数据库中的数据显示到 fullcalendar - 未列出事件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32245898/
我有一个关于 Java Servlet 的问题。 假设我在 servlet 网页“somePage”上。我想登录(使用另一个 servlet,“登录”servlet)。所以我点击“somePage”上
如何将变量数组从一个 servlet 传递到另一个 servlet? 最佳答案 如果您要将当前请求传递给另一个servlet,则只需将其设置为请求属性即可。 request.setAttribute(
什么可能导致此错误? Caused by: jakarta.servlet.UnavailableException: Servlet class org.restlet.ext.servle
我的maven依赖树是这样的 我想问我maven如何解决这个冲突,有两个servlet-api.jar?提前谢谢你。 最佳答案 如果您想从 Velocity 工具中删除 servlet-api,您可以
config ProcessReg ProcessReg text HelloWorld1 public class config implements Serv
您好,我有一个关于 servlet 调用另一个 servlet 的问题 我有一个名为 Relay 的主 servlet,它将负责控制其他 servlet 用户将点击并将转发到 Relay servle
在我的 REST API 项目中,我已将 /* 映射到 RESTServlet,并且需要在同一 WAR 中托管静态内容。我更愿意将 /static/* 映射到 WAS liberty 提供的默认 se
响应映射在 Servlet 中如何工作? 每个响应如何知道清除特定 HTML 或 Handlebars 上的输出? 最佳答案 有一个 ember-java带有 Jersey REST 服务 的 git
有一个 @WebServlet(urlPatterns = "/myServlet/") .如果用户转到 myapp/myServlet/other ,我仍然希望我的 servlet 能够捕获。也就是
我正在使用 Filter 在我的所有页面中插入反点击劫持 header - 这工作正常,除了 JBoss EAP 6.3 容器管理的登录页面,这是更重要的页面之一拥有它。 登录页面根本不调用过滤器,登
我正在尝试使用 RequestDispatcher 将数据从一个 servlet 传递到另一个 servlet。这是我的调度程序代码。 String address; address = "/Java
我刚刚开始使用 Servlet,并设法让一些 Servlet 充当单独的 URL,用于填充数据库以进行一些虚拟测试。某种形式: public class Populate_ServletName ex
我是否需要同时配置app.servlet.version 和 grails.servlet.version? 前者在application.properties中,后者在BuildConfig.gro
在Myeclipse中我创建了一个名为web1的Web项目,并添加了一个名为servlet1的servlet,web.xml如下: servlet1 servlet1
这个问题在这里已经有了答案: How to run a background task in a servlet based web application? (5 个回答) 6年前关闭。 是否可以在
在我的 ManagedBean 中,如果我将范围从 @RequestScoped 更改为 @ViewScoped,我将收到以下错误堆栈。我该如何解决这个问题?不过,当我运行应用程序时,我可以在页面中看
这个问题已经有答案了: How do I execute multiple servlets in sequence? (2 个回答) 已关闭 3 年前。 我已经构建了jdbc-Servlet的代码,
我一直在徒劳地尝试实现 tomcat 9 的 jakarta servlet,而不是以前的 javax.servlet 实现(因为我的理解是 jakarta 包是前进的方向)。问题是,当我将浏览器指向
我是 Spring 新手,正在尝试使用 Maven 部署和运行我的第一个 Spring Web 应用程序。有关更多详细信息,请参阅 here (我昨天发布的一个问题): 现在,我遇到的问题是:当我尝试
我正在尝试学习如何使用 JSP。我遇到了一些毫无意义的事情,至少在我看来是这样: 当我尝试运行时: response.getWriter().println(m.getDb().printAll())
我是一名优秀的程序员,十分优秀!