編程重定向
說說servlet裡面的方法:
public void ValidateUserPass(String user,String pass){
RequestDispathcher rd =null
//假使你的代碼是從DB中獲取
DBFactory db=DBFactoryImpl.getDBFactoryInstance();//得到資料庫鏈接
flg=db.findUser(user,pass);
// 這里是不存在用戶
if(flg.hasNext()==-1){
// 登錄時錯誤了,一般我們會給用戶一個提示
session.setAttirbute("msg","對不起,用戶名或密碼錯誤");
RequestDispathcher rd = req.getRequesDispatcher("login.jsp");
rd.forward(request, reponse);//將請求對象和響應對象傳遞進來
} // 這里是存在當前用戶
else{
//當然這里登錄成功時,我們要把當前用戶寫到session裡面保存
session.setAttirbute("userName",user);
//這個請求轉發語句
request.sendRedirect("index.html");
}
}
// * 上述代碼,你可以參考下我的方法,我也很久沒做JAVA開發了,我現在從事前端UI開發,本來我想在寫一個用struts 2登錄的程序的,可我現在忘得差不多了,上面我所用到的屬性建議你自己好好的研究一下,往後你將學到struts2 hibernate,Spring等一系列優秀的開源框架,說白了,這些東西的底層還是這些,只不過這些框架做了一些封裝隔離。上述代碼建議你重點理解一下:請求轉發和重定向的區別。
㈡ c語言編程 重定向
#include <stdio.h>
#include <stdlib.h>
int main()
{
system("dir >1234.txt");
return 0;
}
date命令似乎系統不支持,上面的代碼可以將dir命令的內容輸出至源文件根目錄的新建的1234.txt中~至於輸出到D盤,這個不多明白……~~~~(>_<)~~~~
㈢ Java中有301HTTP重定向編程嗎
有,請參考
HttpServletResponse.SC_MOVED_PERMANENTLY
你可以直接
response.setStatus(HttpServletResponse.SC_MOVED_PERMANENTLY);來實現301
㈣ Linux 編寫程序輸入一個數,將輸入的數+10後輸出.將其運行結果重定向到
#!/bin/bash
reada
((b=a+10))
echo$b>f1
這個可以把數字寫入f1中
㈤ unix/Linux編程:如何在程序1中調用程序2,實現重定向
用 p 類系統調用即可,很簡單,參考下面重定向 ls 輸出到 test.log 的例子,你可以在這個基礎上做其他程序的重定向:
#include <stdio.h>
#include <unistd.h>
#include <sys/stat.h>
#include <fcntl.h>
int main()
{
int fd;
int pid;
fd = open("test.log", O_WRONLY|O_CREAT, S_IWUSR|S_IRUSR);
pid = fork();
if (pid == 0)
{
/* child, redirect stdout to file */
p2(fd, STDOUT_FILENO);
close(fd);
execlp("/bin/ls", "/bin/ls", "-l", ".", NULL);
}
else
{
wait(NULL);
close(fd);
}
return 0;
}
㈥ java編程中 重定向的特點
java的重定向在struts2,sertvlet跳轉有重定向,和重定向不同的顯示信息的方式是轉發;重定向主要是從action或servlet跳轉到頁面,首先地址欄變化為跳轉指定的路徑,另一點就是重定向的頁面不能使用servlet或action中的全局變數來顯示信息;而轉發相反action或servlet中的全局參數是可以用來顯示信息的,而且地址欄任然是action或者servle的地址
㈦ 如何使用modelandview進行重定向
如何使用modelandview進行重定向
ASP的編程語言是VBScript之類的腳本語言,JSP使用的是Java,這是兩者最明顯的區別。
此外,ASP與JSP還有一個更為本質的區別:兩種語言引擎用完全不同的方式處理頁面中嵌入的程序代碼。在ASP下,VBScript代碼被ASP引擎解釋執行;在JSP下,代碼被編譯成Servlet並由Java虛擬機執行,這種編譯操作僅在對JSP頁面的第一次請求時發生。
㈧ 編程題:要求用重定向的方法設計一個JSP頁面,輸出0~1之間的任意隨機數。
response.sendRedirect("random.jsp");
out.println(Math.random());
㈨ 如何在一個shell程序中取消重定向
shell腳本中取消重定向的方法實例
這篇文章主要介紹了shell腳本中取消重定向的方法實例,本文直接給出代碼實例,需要的朋友可以參考下
在上一篇關於shell編程的例子中,有講到把shell腳本進行擴展之後重定向到一個文件中,以便進行查看和調試http://www.jb51.net/article/62435.htm。但是,若是有另一種情況:只是在某些地方進行重定向,而其他地方不進行重定向。那麼我們就來修改一下上一篇中的例子來進行這種需求的滿足:
復制代碼代碼如下:
#!/bin/bash
function setlogfile
{
if ! [ -z "$1" ]; then
echo "logfilename is not empty!" >> kthh
exec 3>&1
exec 4>&2
exec 2>> $1
exec 1>> $1
fi
}
num1=$1
logfile=$2
execlogfile=$3
setlogfile ${execlogfile}
set -x
if [ $num1 -eq 0 ]; then
echo "num1 is 0">> ${logfile}
elif [ $num1 -ge 0 ]; then
echo "num1 is grate 0">> ${logfile}
else
echo "num1 is less 0">> ${logfile}
fi
exec 2>&4
exec 1>&3
if [ $num1 -eq 0 ]; then
echo "num1 is 0 again">> ${logfile}
fi
在函數setlogfile中添加了exec 3>&1;exec 4>&2這兩句,而其中,3、1、4、2都是表示文件描述符,1是標准輸出,也即是STDOUT,2是標准錯誤輸出,即是STDERR,1和2本來是輸出在顯示器上的,而3、4是表示兩個文件描述符,可理解成是兩個保存1和2的臨時變數, 3>&1表示把文件描述符1的賦值給文件描述符3,也可以理解為是把文件描述符1(當前標准輸出)的規則保存到了文件描述符3中,這時再把1的輸出重定向到文件中,在下面的shell程序中,我們又使用了1>&3這就表示是把保存在文件描述符3中的原標准輸出的規則重新賦值給文件描述符1,原來標准輸出的規則是輸出到顯示器上,而不是輸出到一個文件中。這就是整個重定向和取消重定向還原的過程。2和4也是一樣的道理。
閑話少說,先看運行結果:
復制代碼代碼如下:
[root@UFO shellprogram]# ./testexecutelog.sh 0 msglog execlog
+ exec
+ '[' 0 -eq 0 ']'
+ echo 'num1 is 0 again'
[root@UFO shellprogram]# cat execlog
+ '[' 0 -eq 0 ']'
+ echo 'num1 is 0'
+ exec
看到結果了嗎??? 沒看到么??? 那就仔細看了,^_^
㈩ SHELL編程 輸出重定向
grep -v $bbb xxx.txt | cat >xxx.txt
在管道前後對同一個文件操作很危險。這樣同時有兩個程序對同一個文件讀寫,會產生競爭。最後的結果不好確定。最好分開處理。
rep -v $... xxx.txt >xxx.txt 這樣做也不好。通過重定向後也會發生對同一個文件同時讀寫的情況。 但至少是同一個程序來控制(如果不算shell)。grep可能已經考慮過這樣的情況,或者巧合(處理時先讀,再寫), 所以結果正確。但同其他程序的配合,情況就更復雜了,很可能出現問題。
具體要看grep,shell和cat代碼。
但總體上,不建議這樣做。這樣做是極危險的行為。最好用一個備份文件,避免同時對一個文件讀寫操作。