如何在不使用表单的情况下从jsp调用servlet

时间:2012-02-13 06:49:55

标签: java javascript html jsp servlets

这可能是一个重复的问题,我道歉。我有一个jsp页面,其中有一些按钮。每个按钮都有自己的servlet来调用。我想知道是否有任何方法可以在不使用表单的情况下调用这些servlet,因为用户可以选择给出的3个功能中的任何一个。我还需要将一个值从jsp页面传递给我调用的servlet。

<html>  
<head>  
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">  
<title>Configurations</title>  
<script type="text/javascript">  
    function runConfiguration(){  
        var config=${dataValues.get(0)};  
        //call servlet  
    }  
    function editConfiguration(){  
        var config=${dataValues.get(0)};  
        //call servlet  
    }  
    function deleteConfiguration(){  
        var config=${dataValues.get(0)};  
        //call servlet  
    }  
</script>  
</head>  
<body>  
<%  
String[] label={"Master Port","Baud Rate","Char Size","Stop Bits","Parity","RTU Port","Baud Rate","Char Size","Stop Bits", "Parity"};  
int i=0;  
%>  
<br>  
<br>  
<br>  
<table align="center" border="1">  
   <td><div align="center" style="background-color: goldenrod;"><b> ${dataValues.get(0)}</b></div>   
        <table width="210" align="left" border="1">  
            <td bgcolor="goldenrod"><b> Header1 </b></td>  
            <c:forEach var="data" begin="1" end="5" items="${dataValues}" varStatus="status">  
            <tr>  
                <td><%=label[i++]%>: ${data}</td>  
            </tr>  
            </c:forEach>  
        </table>      
        <table width="210" align="left" border="1">  
            <td bgcolor="goldenrod"><b> Header2 </b></td>  
            <c:forEach var="data" begin="6" end="10" items="${dataValues}" varStatus="status">  
            <tr>  
                <td><%=label[i++]%>: ${data}</td>  
            </tr>  
        </c:forEach>  
        </table>  
   </td>  
</table>  
        <c:choose>  
        <c:when test="${dataValues.get(11)==1}">  
                <p align="center"><b><i>This configuration is already running</i></b></p>  
                <p align="center">  
            <input type="button" value="stop" onclick="StopConfiguration"/>  
                </p>  
        </c:when>  
        <c:otherwise>  
                <p align="center"><b><i>This configuration is currently NOT running</i></b></p>  
                <p align="center">                     
                    <button type="button" onclick="runConfiguration()">Run</button>  
                    <button type="button" onclick="editConfiguration()">Edit</button>  
                    <button type="button" onclick="deleteConfiguration()">Delete</button>  
                </p>  
        </c:otherwise>  
    </c:choose>  
</body>  
</html>  

5 个答案:

答案 0 :(得分:3)

我在这里看到两个选项:

  1. 在发送POST请求之前,使用JavaScript相应地更改表单的URL;

  2. 对所有3种情况使用表单和相同的servlet。在servlet中,您应该确定按下了什么按钮(它们的值作为请求参数传递)然后相应地前进。

答案 1 :(得分:0)

您可以使用Ajax执行此操作或更糟糕但可运行的方式,您可以更改当前窗口网址并重新加载页面。

对于Ajax调用,我建议您使用ExtJS。见Ext.Ajax Usage

其他方式:change the hrefreload the window

答案 2 :(得分:0)

请在JSP&amp;中指定操作字符串。在你的servlet中检查它。

根据该字符串操作,您可以在servlet代码中设置条件,以确定要执行特定操作的操作。 请看下面这是我在我的代码中所做的。

例如

<A href="<%=request.getContextPath()%>/JobAction?action=runConfig">RUN</a>

<a href="<%=request.getContextPath()%>/JobAction?action=editConfig">EDIT</a>

您可以只调用一个servlet,而不是调用多个servlet。 在servlet中使用这样的代码。

String action = request.getParameter("action");
if (action.equalsIgnoreCase("runConfig")) {
    // Specify what you want to do
} else if (action.equalsIgnoreCase("editConfig")) {
    // Specify what you want to do
} else if (action.equalsIgnoreCase("deleteConfig")) {
    // Specify what you want to do
}

答案 3 :(得分:0)

您也可以使用Javascript,当用户点击按钮时调用脚本并动态更改网址并提交该表单。
这是一个例子.....

    <form action = "something".....>
    your stuff here....
    <button type="button" onclick="runConfiguration(actionName)">Run</button>  
    <button type="button" onclick="editConfiguration(actionName)">Edit</button>
    <button type = "button" onclick = "deleteConfiguration(actionName)">Delete</button> 

并在你的脚本中

    <script type="text/javascript">  
        function runConfiguration(actionName){  
            var config=${dataValues.get(0)};
            goToPage(actionName);
            //call servlet  
        }  
        function editConfiguration(actionName){  
            var config=${dataValues.get(0)};
             goToPage(actionName)  
            //call servlet  
        }  
        function deleteConfiguration(actionName){  
            var config=${dataValues.get(0)};
             goToPage(actionName)  
            //call servlet  
        } 

function gotopage(actionname)
{   
        document.formName=actionname;
        document.formName.submit();
} 
    </script>  

答案 4 :(得分:-1)

你可以使用这个:

<a href="<%=request.getContextPath()%>/logout"> Logout </a>

如果你想给它添加一些引导程序,你所要做的就是

<a href="<%=request.getContextPath()%>/logOut"> 
    <button class="btn btn-outline-secondary" type="button">log out </button>
</a>