版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、<p><b> 課 程 設(shè) 計</b></p><p> 課程名稱___操作系統(tǒng)__________</p><p> 題目名稱___多級文件系統(tǒng)-1_____</p><p> 學(xué)生學(xué)院___計算機(jī)學(xué)院________</p><p> 專業(yè)班級__ 10級網(wǎng)絡(luò)3班______</p>
2、<p> 2013年 7 月 1 日</p><p><b> 目錄</b></p><p> 1.設(shè)計目的.....................................................................4</p><p> 2.設(shè)計內(nèi)容.................
3、....................................................4</p><p> 3.運(yùn)行環(huán)境及開發(fā)技術(shù)說明............................................4</p><p> 4.設(shè)計步驟.........................................................
4、.............5</p><p> 5.心得體會......................................................................16</p><p> 6.主要實(shí)現(xiàn)代碼...............................................................16</p>
5、;<p><b> 1.設(shè)計目的:</b></p><p> 本課程設(shè)計要求設(shè)計一個模擬的多用戶多級目錄的文件系統(tǒng)。通過具體的文件存儲空間的管理、文件的物理結(jié)構(gòu)、目錄結(jié)構(gòu)和文件操作的實(shí)現(xiàn),加深對文件系統(tǒng)內(nèi)部功能和實(shí)現(xiàn)過程的理解。 </p><p><b> 2.設(shè)計內(nèi)容:</b></p><p> 首
6、先在內(nèi)存中開辟一個虛擬磁盤空間作為文件存儲器,在其上實(shí)現(xiàn)一個多用戶多目錄的文件系統(tǒng)。其中文件物理結(jié)構(gòu)可采用顯式鏈接。另外磁盤空閑空間的管理選擇位示圖。由于采用位示圖來管理文件存儲空間,并采用顯式鏈接分配方式,則可以將位示圖合并到FAT中。</p><p> 文件目錄結(jié)構(gòu)采用多用戶多級目錄結(jié)構(gòu),每個目錄項包含文件名、物理</p><p> 地址、長度等信息,還可以通過目錄項實(shí)現(xiàn)對文件的讀
7、和寫的保護(hù)。</p><p> 另外設(shè)計一個的用戶界面,提供以下相關(guān)文件操作:</p><p> (1)具有l(wèi)ogin (用戶登錄);</p><p> (2)系統(tǒng)初始化(建文件卷、提供登錄模塊);</p><p> ?。?)文件的創(chuàng)建: create;</p><p> ?。?)文件的打開:open;</
8、p><p> ?。?)文件的讀:read;</p><p> ?。?)文件的寫:write;</p><p> ?。?)文件關(guān)閉:close;</p><p> ?。?)刪除文件:delete ;</p><p> ?。?)創(chuàng)建目錄(建立子目錄):mkdir;</p><p> ?。?0)改變當(dāng)前目
9、錄:cd;</p><p> ?。?1)列出文件目錄:dir;</p><p> ?。?2)退出:logout。</p><p> 3.運(yùn)行環(huán)境及開發(fā)技術(shù)說明:</p><p> 1.本課程設(shè)計是用web的形式模擬多級用戶多目錄文件系統(tǒng)。本系統(tǒng)用到技術(shù)有jsp+Tomcat+mysql。</p><p> 2.系
10、統(tǒng)運(yùn)行的環(huán)境:配置好java的jre1.5及以上版本,Tomcat6.0版本,mysql5.5版本,eclipse10.0版本。</p><p> 3.運(yùn)行系統(tǒng)說明:將項目導(dǎo)入eclipse或者直接把項目文件夾復(fù)制到tomcat的webapp目錄下,打開tomcat服務(wù)器,再在瀏覽器地址欄輸入</p><p> 即可進(jìn)入系統(tǒng)的登錄頁面:</p><p><
11、b> 4.設(shè)計步驟:</b></p><p><b> (1)需求分析。</b></p><p> 本系統(tǒng)為多用戶多目錄的文件管理系統(tǒng),用戶可以對文件或是文件目錄進(jìn)行操作。多用戶功能可以滿足不同用戶不同的需求,同時因增加了管理員登陸和用戶登錄功能使得系統(tǒng)起到了很好的保密作用。</p><p> 文件系統(tǒng)是操作系統(tǒng)中負(fù)責(zé)
12、管理和存取文件信息的機(jī)構(gòu),它具有“按名存取”的功能,已使得用戶能透明的存儲和訪問文件。為了是實(shí)現(xiàn)按名存取,文件需要對文件存儲設(shè)備進(jìn)行合理化的組織,分配;對存儲設(shè)備上的文件進(jìn)行保護(hù),保密和提供共享的手段。文件系統(tǒng)主要實(shí)現(xiàn)對具體的文件存取空間的管理、文件的物理結(jié)構(gòu)、目錄結(jié)構(gòu)管理和文件操作。另外文件系統(tǒng)還要提供檢索文件或是文件中記錄的手段,文件系統(tǒng)就是完成上述功能的一組軟件和數(shù)據(jù)結(jié)構(gòu)的集合。</p><p> 而模擬
13、一個多用戶多級目錄的文件管理系統(tǒng),要完成對文件的基本操作,文件的基本操作有文件,文件夾的新建、打開、讀取、寫入文件、創(chuàng)建更改目錄、修改文件內(nèi)容、刪除、列出目錄內(nèi)容等信息。系統(tǒng)建立了文件目錄樹,存儲文件中的所有文件。對于用戶名下的文件,用文件目錄樹的分枝來存儲。另外由于文件系統(tǒng)提供了安全保密功能,所有模擬文件系統(tǒng)還需要有管理員登陸和創(chuàng)建用戶和用戶登錄,密碼修改等功能。</p><p> 另外,為了方便操作,還需模
14、擬一個操作界面,方便用戶進(jìn)行操作。</p><p><b> (2)概要設(shè)計:</b></p><p><b> 1).設(shè)計思想</b></p><p> 文件系統(tǒng)是操作系統(tǒng)中負(fù)責(zé)管理和存取文件信息的機(jī)構(gòu),它具有“按名存取”的功能。文件系統(tǒng)主要實(shí)現(xiàn)對具體的文件存取空間的管理、文件的物理結(jié)構(gòu)、目錄結(jié)構(gòu)管理和文件操作。&
15、lt;/p><p> 本實(shí)驗(yàn)中的文件系統(tǒng)是多用戶多級目錄的文件系統(tǒng)。實(shí)驗(yàn)中定義用戶的上限為5個,目錄結(jié)構(gòu)采用多級目錄結(jié)構(gòu)</p><p> 2).抽象數(shù)據(jù)類型的定義</p><p> //連接數(shù)據(jù)庫在數(shù)據(jù)類型保存在數(shù)據(jù)庫中</p><p> /*create database homework;*/</p><p>
16、; use homework;</p><p><b> /*用戶表*/</b></p><p> create table user</p><p><b> (</b></p><p> id int primary key auto_increment,</p><
17、;p> name varchar(100),</p><p> password varchar(150)</p><p><b> );</b></p><p><b> /*目錄表 */</b></p><p> create table directory</p>
18、<p><b> (</b></p><p> id int primary key auto_increment,</p><p> name varchar(100),</p><p> pathp varchar(100), /* 表途徑*/</p><p> pdate datetime
19、</p><p><b> );</b></p><p><b> /*文件表*/</b></p><p> create table ufile</p><p><b> (</b></p><p> id int primary key a
20、uto_increment,</p><p> name varchar(100),</p><p> content varchar(100), /*文件內(nèi)容*/</p><p> pdate datetime,</p><p> pathu varchar(100) /* 表途徑*/</p><p>&l
21、t;b> );</b></p><p> create table priority </p><p><b> (</b></p><p> id int primary key auto_increment,</p><p> fileName varchar(100),/*文件名稱*/&
22、lt;/p><p> userName varchar(100),/*用戶名*/</p><p> r int, /*1表示可讀,0表示不可讀 */</p><p> w int, /*1表示可寫,0表示不可寫 */ </p><p> exe int /*1表示可執(zhí)行,0表示不可執(zhí)行*/ </p><p>&l
23、t;b> );</b></p><p> /*insert into ufile vaules (null,'a','aa',,now(),'A')*/</p><p> /*初始化目錄表*/</p><p> insert into directory values (null,'r
24、oot','A',now() );</p><p> insert into directory values (null,'root','B',now() );</p><p> insert into directory values (null,'root','C',now() );</
25、p><p> 3).主程序的流程以及各程序模塊之間的層次(調(diào)用)關(guān)系。</p><p> 在系統(tǒng)中設(shè)置了用戶登陸模式。用戶初始化時不存在,則可在注冊。注冊成功后方可進(jìn)行登錄,登錄成功后則可進(jìn)行一系列的操作。如</p><p> 用戶注冊:register.jsp</p><p> 用戶登錄:login.jsp </p>&
26、lt;p> 磁盤的初始化:art_mana.jsp //建立3個分區(qū)</p><p> 文件的創(chuàng)建:info_ufile.jsp//建立新文件</p><p> 文件的打開:file_mana.jsp//打開文件</p><p> 文件刪除:delete__file.jsp//刪除文件</p><p> 文件的讀:che
27、ck_file.jsp//查看文件</p><p> 創(chuàng)建目錄(建立子目錄):info_dir.jsp//建立新目錄</p><p> 查看當(dāng)前目錄:file_mana.jsp //顯示目錄</p><p> 刪除目錄:delete_dir.jsp//刪除目錄</p><p> 返回上一級目錄:main.jsp//向上返回
28、</p><p> 退出: main.jsp //退出功能</p><p> (3)詳細(xì)設(shè)計:實(shí)現(xiàn)概要設(shè)計中定義的功能;畫出函數(shù)的調(diào)用關(guān)系圖;畫出各程序流程圖。</p><p> (4)部分功能模塊流程圖:</p><p><b> 用戶登錄模塊</b></p><p> 用戶首次登錄要
29、注冊,用戶登錄模塊要求用戶輸入賬號與密碼,當(dāng)輸入正確后進(jìn)入主視圖才能進(jìn)行其他模塊操作,否則提示賬號密碼錯誤并要求用戶重新輸入。用戶包括普通用戶和超級用戶。超級用戶可以修改其他用戶的權(quán)限,使他們可以修改其他用戶創(chuàng)建的文件。</p><p><b> yes</b></p><p><b> no</b></p><p>
30、 Yes no</p><p><b> no</b></p><p> B.修改文件功能結(jié)構(gòu)圖</p><p><b> yes</b></p><p><b> no</b></p><p><b> no&l
31、t;/b></p><p><b> yes</b></p><p> (5)系統(tǒng)測試:列出所有系統(tǒng)功能的測試結(jié)果,測試數(shù)據(jù)應(yīng)該完整、嚴(yán)格,應(yīng)該至少包含需求分析中所列。</p><p> 1)若不是用戶 先注冊 注冊如下:</p><p><b> 2)用戶登錄功能:</b><
32、/p><p> 登錄成功后可進(jìn)行用戶的操作:</p><p> 3)系統(tǒng)初始化:及磁盤的分區(qū)</p><p> 目錄的創(chuàng)建:(創(chuàng)建子目錄)</p><p> 在A盤下創(chuàng)建目錄home</p><p><b> 結(jié)果如下:</b></p><p><b>
33、5)創(chuàng)建文件</b></p><p> 如在A盤目錄home中創(chuàng)建文件myfile</p><p><b> 如下</b></p><p> 6)文件的打開:(查看)</p><p><b> 7)文件的讀取</b></p><p><b>
34、結(jié)果如下</b></p><p> 8)文件的寫:(修改)</p><p><b> 結(jié)果如下:</b></p><p> 9)文件的刪除(刪除)</p><p> 刪除myfile結(jié)果如下</p><p> 10)改變當(dāng)前目錄(修改)</p><p>
35、; 將home修改為home-lzf</p><p><b> 結(jié)果如下</b></p><p><b> 11)列出目錄</b></p><p> 如B目錄下有目錄和文件</p><p> 12)用戶修改密碼的功能:</p><p><b> 13)用
36、戶退出功能</b></p><p><b> 返回用戶登錄界面</b></p><p> 14)用其他用戶zj登錄修改前面lzf用戶創(chuàng)建的文件myfile2</p><p> 修改myfile2文件</p><p><b> 結(jié)果如下圖:</b></p><p
37、> 用root用戶修改zj對myfile2的權(quán)限修改,時他能修改myfile2</p><p><b> 修改權(quán)限</b></p><p> 修改后,再用zj用戶修改lzf用戶創(chuàng)建的文件myfile2</p><p><b> (6)系統(tǒng)文件說明</b></p><p> Regis
38、ter.jsp:用戶注冊;login.jsp:用戶登錄;art_mana.jsp:磁盤初始化; info_dir.jsp建立目錄</p><p> Info_ufile.jsp新建文件,file_mana.jsp打開文件,delete_file.jsp刪除文件;check_file.jsp查看文件;main.jsp主頁面,prioritDdit.jsp修改權(quán)限;priorityEditDeal.jsp修改權(quán)限處
39、理。faithConn.jsp連接錯誤頁面;faithregister.jsp注冊錯誤頁面。</p><p><b> 5.心得體會。</b></p><p> 在做課程設(shè)計的過程中遇到很多的問題,因?yàn)槭怯胘ava web 來做的,系統(tǒng)在顯示的效果上并不是很好,但是都基本上完成了實(shí)驗(yàn)的要求,如多用戶多目錄的文件系統(tǒng)要求的多用戶登錄,每個用戶進(jìn)去后都可以創(chuàng)建自己的目
40、錄和文件。但是每個用戶創(chuàng)建的文件只能是自己修改,除非root用戶修改其他用戶的權(quán)限。</p><p> 在編程此系統(tǒng)時,方發(fā)覺自己對文件系統(tǒng)理解得不夠透徹。例如在考慮如何實(shí)現(xiàn)多用戶多目錄時,雖然書本上樹行目錄的圖看起來很清晰,但一編程起來就好像往二級目錄思路那樣編程了。</p><p> 通過這次實(shí)驗(yàn),讓我對操作系統(tǒng)的多級用戶多目錄文件系統(tǒng)有了更深的理解,對文件系統(tǒng)的文件組織形式和存儲
41、方式有了更深的理解。</p><p> 最后通過用java 編程有加深了對java知識點(diǎn)的理解和java web的理解。</p><p> 總之,這次課程設(shè)計讓自己受益匪淺。</p><p><b> 6.主要實(shí)現(xiàn)代碼。</b></p><p><b> ?。?)相關(guān)類定義</b></
42、p><p><b> A)連接數(shù)據(jù)庫類</b></p><p> public class DB {</p><p> public static Connection getConn() {</p><p> Connection conn = null; </p><p><b>
43、; try {</b></p><p> Class.forName("com.mysql.jdbc.Driver");</p><p> conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/homework", "root" , &qu
44、ot;123456");</p><p> } catch (ClassNotFoundException e) {</p><p> e.printStackTrace(); </p><p> } catch (SQLException e) { </p><p> e.printStackTrace(); </
45、p><p><b> }</b></p><p> return conn;</p><p><b> }</b></p><p> public static Statement createStmt(Connection conn) {</p><p> State
46、ment stmt = null;</p><p><b> try {</b></p><p> stmt = conn.createStatement();</p><p> } catch (SQLException e) {</p><p> e.printStackTrace();</p>
47、<p><b> }</b></p><p> return stmt;</p><p><b> }</b></p><p> public static ResultSet executeQuery(Statement stmt, String sql) {</p><p>
48、 ResultSet rs = null;</p><p><b> try {</b></p><p> rs = stmt.executeQuery(sql);</p><p> } catch (SQLException e) {</p><p> e.printStackTrace();</p&g
49、t;<p><b> } </b></p><p> return rs;</p><p><b> }</b></p><p><b> }</b></p><p><b> B)目錄類</b></p><p&
50、gt; public class Directory {</p><p> private int id;</p><p> private String name;</p><p> private String pathp; /* 父節(jié)點(diǎn),表途徑*/</p><p> private Date pdate;</p&g
51、t;<p> public void saveRs(ResultSet rs) {</p><p><b> try {</b></p><p> setId(rs.getInt("id"));</p><p> setName(rs.getString("name"));</
52、p><p> setPathp(rs.getString("pathp"));</p><p> setPdate(rs.getTimestamp("pdate"));</p><p> } catch (SQLException e) {</p><p> e.printStackTrace();
53、</p><p><b> }</b></p><p><b> }</b></p><p><b> C)權(quán)限類</b></p><p> public class Priority {</p><p> private int id;<
54、;/p><p> private String fileName;</p><p> private String userName;</p><p> private int r;</p><p> private int w;</p><p> private int exe;</p><
55、p> public void saveRs(ResultSet rs) {</p><p><b> try {</b></p><p> setId(rs.getInt("id"));</p><p> setFileName(rs.getString("fileName"));</
56、p><p> setUserName(rs.getString("userName"));</p><p> setR(rs.getInt("r"));</p><p> setW(rs.getInt("w"));</p><p> setExe(rs.getInt("
57、exe"));</p><p> } catch (SQLException e) {</p><p> e.printStackTrace();</p><p><b> }</b></p><p><b> }</b></p><p><b>
58、 D)文件類</b></p><p><b> /*文件表*/</b></p><p> public class Ufile {</p><p> private int id;</p><p> private String name;</p><p> private
59、 String content;</p><p> private Date pdate;</p><p> private String pathu ;/*表路徑*/ </p><p> public void saveRs(ResultSet rs) {</p><p><b> try {</b><
60、/p><p> setId(rs.getInt("id"));</p><p> setName(rs.getString("name"));</p><p> setContent(rs.getString("content"));</p><p> setPdate(rs.g
61、etTimestamp("pdate"));</p><p> setPathu(rs.getString("pathu"));</p><p> } catch (SQLException e) {</p><p> e.printStackTrace();</p><p><b>
62、 }</b></p><p><b> }</b></p><p><b> E)用戶文件表</b></p><p> public class User {</p><p> private int id; </p><p> private Stri
63、ng name;</p><p> private String password; </p><p> public void saveRs(ResultSet rs) {</p><p><b> try {</b></p><p> setId(rs.getInt("id"));<
64、/p><p> setName(rs.getString(name));</p><p> setPassword(rs.getString(password));</p><p> } catch (SQLException e) {</p><p> e.printStackTrace();</p><p>&
65、lt;b> }</b></p><p><b> }</b></p><p> ?。?)登錄功能代碼:</p><p><b> <%</b></p><p> boolean success=true;</p><p> request.s
66、etCharacterEncoding("GBK");</p><p> String username = (String)request.getParameter("username");</p><p> System.out.println(username);</p><p> String password
67、=(String)request.getParameter("password");</p><p> System.out.println(password);</p><p> Connection conn = DB.getConn();</p><p> Statement stmt=DB.createStmt(conn);&l
68、t;/p><p> String sql = "select * from user where name='"+ username +"'and password='"+ password +"'";</p><p> System.out.print(sql);</p><p
69、> ResultSet rs = DB.executeQuery(stmt, sql);</p><p> if(!rs.next()){</p><p> success=false;</p><p><b> }</b></p><p> DB.close(rs);</p><p&
70、gt; DB.close(stmt);</p><p> DB.close(conn);</p><p> if(success){</p><p> session.setAttribute("username", username);</p><p> response.sendRedirect("
71、mian.jsp");</p><p><b> }else{</b></p><p> out.print("登錄失敗,請重新登錄");</p><p> response.sendRedirect("faithlogin.jsp");</p><p><b
72、> }</b></p><p><b> %></b></p><p><b> (3)注冊功能代碼</b></p><p><b> <%</b></p><p> String path = request.getContextPat
73、h();</p><p> String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";</p><p><b> %></b></p>
74、<p><b> <%</b></p><p> String username=request.getParameter("username");</p><p> String password=request.getParameter("password");</p><p>
75、; String repassword=request.getParameter("repassword");</p><p> if(username!=null&&password!=null&&repassword.equals(password))</p><p><b> {</b></p>
76、;<p> session.setAttribute("username", username);</p><p> session.setAttribute("password", password); </p><p> response.sendRedirect("check_register.jsp"
77、;); </p><p><b> } </b></p><p><b> %></b></p><p> <script type="text/javascript"></p><p> function check()</p&g
78、t;<p><b> {</b></p><p> if(form.username.value=="")</p><p><b> {</b></p><p> alert("請輸入用戶名!");</p><p> form.user
79、name.focus();</p><p> return false;}</p><p> if(form.password.value==""){</p><p> alert("請輸入密碼!");</p><p> form.password.focus();</p><
80、;p> return false;} </p><p> }</script></p><p><b> ?。?)創(chuàng)建目錄代碼</b></p><p><b> <% </b></p><p> request.setCharacterEncoding("
81、GBK");</p><p> String ppath=(String)session.getAttribute("ppath");</p><p> String action = request.getParameter("action");</p><p> if (action != null &am
82、p;& action.trim().equals("post")) {</p><p> String name = (String)request.getParameter("name");</p><p> System.out.println(name);</p><p> //String ppath =
83、 (String)request.getParameter("ppath");</p><p> //System.out.println(path);</p><p> String tpath=(ppath+'/'+name).trim();</p><p> Connection conn = DB.getConn()
84、;</p><p> boolean autoCommit = conn.getAutoCommit();</p><p> conn.setAutoCommit(false);</p><p> //insert into directory values (null,'root','A',now() );</p>
85、<p> String sql = "insert into directory values (null, ?, ?, now())";</p><p> PreparedStatement pstmt = DB.prepareStmt(conn, sql, Statement.RETURN_GENERATED_KEYS);</p><p> ps
86、tmt.setString(1, name);</p><p> pstmt.setString(2,tpath);</p><p> pstmt.executeUpdate();</p><p> conn.commit();</p><p> conn.setAutoCommit(autoCommit);</p>&
87、lt;p> DB.close(pstmt);</p><p> DB.close(conn);</p><p> response.sendRedirect("art_mana.jsp");</p><p><b> }else{</b></p><p> String pathp =
88、 request.getParameter("pathp");</p><p> System.out.println(pathp);</p><p> session.setAttribute("ppath", pathp);</p><p><b> }</b></p><p
89、><b> %></b></p><p> ?。?)創(chuàng)建文件代碼:</p><p><b> <% </b></p><p> request.setCharacterEncoding("GBK");</p><p> String ppath=(St
90、ring)session.getAttribute("ppath");</p><p> System.out.println(ppath+"路徑2");</p><p> String action = request.getParameter("action");</p><p> if (act
91、ion != null && action.trim().equals("post")) {</p><p> String name = (String)request.getParameter("name");</p><p> System.out.println(name);</p><p> S
92、tring content = (String)request.getParameter("content");</p><p> System.out.println(content);</p><p> String userName =(String)session.getAttribute("username");</p>
93、<p> /*int r = request.getParameter("r");</p><p> System.out.println(r);</p><p> int w = (Integer)request.getParameter("w");</p><p> System.out.println(
94、w);</p><p> int exe = (Integer)request.getParameter("exe");</p><p> System.out.println(exe);</p><p> //String ppath = (String)request.getParameter("ppath");&l
95、t;/p><p> //System.out.println(path);*/</p><p> Connection conn = DB.getConn();</p><p> boolean autoCommit = conn.getAutoCommit();</p><p> conn.setAutoCommit(false);&l
96、t;/p><p> /*insert into ufile vaules (null,'a','aa','A',now(),1,1,1)*/</p><p> String sql = "insert into ufile values (null, ?, ? , now(),?)";</p><p&g
97、t; String prioritySql = "insert into priority values (null,?,?,1,1,1)";</p><p> PreparedStatement pstmt = DB.prepareStmt(conn, sql, Statement.RETURN_GENERATED_KEYS);</p><p> Prepare
98、dStatement p2stmt = DB.prepareStmt(conn, prioritySql, Statement.RETURN_GENERATED_KEYS);</p><p> pstmt.setString(1,name);</p><p> pstmt.setString(2, content);</p><p> pstmt.setStr
99、ing(3, ppath);</p><p> pstmt.executeUpdate();</p><p><b> //加入權(quán)限表</b></p><p> p2stmt.setString(1,name);</p><p> p2stmt.setString(2,userName);</p>
100、<p> p2stmt.executeUpdate();</p><p> conn.commit();</p><p> conn.setAutoCommit(autoCommit);</p><p> DB.close(pstmt);</p><p> DB.close(conn);</p><p&
101、gt; response.sendRedirect("art_mana.jsp");</p><p><b> }else{</b></p><p> String pathp = (String)request.getParameter("pathp");</p><p> System.out
102、.println(pathp+"途徑1");</p><p> session.setAttribute("ppath", pathp);</p><p><b> }</b></p><p><b> %></b></p><p><b&g
103、t; ?。?)編輯文件代碼</b></p><p><b> <%</b></p><p> String name=null;</p><p> String content=null;</p><p> String pathu=null;</p><p> req
104、uest.setCharacterEncoding("GBK");</p><p> int id = Integer.parseInt(request.getParameter("id"));</p><p> System.out.print(id+"3333333");</p><p> Con
105、nection conn = DB.getConn();</p><p> Statement stmt=DB.createStmt(conn);</p><p> String sql = "select * from ufile where id='"+ id +"'";</p><p> Syste
106、m.out.print(sql);</p><p> ResultSet rs = DB.executeQuery(stmt, sql);</p><p> if(rs.next()){</p><p> name=rs.getString("name");</p><p> content=rs.getStrin
107、g("content");</p><p> pathu=rs.getString("pathu");</p><p> System.out.print(name);</p><p> System.out.print(content);</p><p><b> }</b&g
108、t;</p><p> DB.close(rs);</p><p> DB.close(stmt);</p><p> DB.close(conn);</p><p><b> %></b></p><p><b> (7)修改權(quán)限代碼</b></p&g
109、t;<p> <%request.setCharacterEncoding("GBK");</p><p> String filename=(String)request.getParameter("filename");</p><p> String username=(String)request.getParam
110、eter("username");</p><p> int r = 0;</p><p> int w = 0;</p><p> int exe =0;</p><p> PrintWriter pout = response.getWriter();</p><p> Conne
111、ction cconn = DB.getConn();</p><p> Statement cstmt=DB.createStmt(cconn);</p><p> String csql = "select * from priority where filename='"+ filename +"'" +" and
112、 username='"+ username +"'";</p><p> ResultSet crs = DB.executeQuery(cstmt, csql);</p><p> if(crs.next()){</p><p> filename=crs.getString("filename&qu
113、ot;);</p><p> username=crs.getString("username");</p><p> r = crs.getInt("r");</p><p> w = crs.getInt("w");</p><p> exe = crs.getInt(&
114、quot;exe");</p><p><b> }</b></p><p><b> %></b></p><p><b> <html></b></p><p><b> <body></b></p
115、><p> page of priority edit ...</p><p> <form action="priorityEditDeal.jsp" method="post" ></p><p> <input type="hidden" name="id"
116、/></p><p> <label>文件名:</label><input type="text"name="filename" value=<%=filename%> /><br></p><p> <label>用戶名:</label><input
117、 type="text"name="username" value=<%=username%>/><br></p><p> <label>可  讀:</label><input type="text"name="r" value=<
118、%=r%>/><br></p><p> <label>可  寫:</label><input type="text"name="w" value=<%=w%>/><br></p><p> <label>可執(zhí)行:&l
119、t;/label><input type="text"name="exe" value=<%=exe%>/><br></p><p> <input type="submit" value="提交" /></p><p><b> <%&
120、lt;/b></p><p> String path = request.getContextPath();</p><p> String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"
121、;/";</p><p><b> %></b></p><p> <%request.setCharacterEncoding("GBK");</p><p> String filename=(String)request.getParameter("filename")
122、;</p><p> String username=(String)request.getParameter("username");</p><p> int r = Integer.parseInt(request.getParameter("r"));</p><p> int w = Integer.pars
123、eInt(request.getParameter("w"));</p><p> int exe =Integer.parseInt(request.getParameter("exe"));</p><p> System.out.println(filename+"#"+username+"#"+
124、r+"#"+w+"#"+exe);</p><p> PrintWriter pout = response.getWriter();</p><p> Connection cconn = DB.getConn();</p><p> Statement cstmt=DB.createStmt(cconn);<
125、/p><p> String csql = "select * from priority where filename='"+ filename +"'" +" and username='"+ username +"'";</p><p> ResultSet crs = D
126、B.executeQuery(cstmt, csql);</p><p> if(!crs.next()){ </p><p> System.out.println("!crs.next()");</p><p> Connection conn = DB.getConn();</p><p> boolean
127、autoCommit = conn.getAutoCommit();</p><p> conn.setAutoCommit(false);</p><p> String sql = "insert into priority values (null, ?, ?,?,?,?)";</p><p> PreparedStatement p
128、stmt = DB.prepareStmt(conn, sql, Statement.RETURN_GENERATED_KEYS);</p><p> pstmt.setString(1, filename);</p><p> pstmt.setString(2, username);</p><p> pstmt.setInt(3,r);</p>
129、;<p> pstmt.setInt(4,w);</p><p> pstmt.setInt(5,exe);</p><p> pstmt.executeUpdate();</p><p> conn.commit();</p><p> conn.setAutoCommit(autoCommit);</p>
130、;<p> pout.println("權(quán)限修改成功");</p><p> DB.close(pstmt);</p><p> DB.close(conn); </p><p><b> }</b></p><p> else if(crs.next()){&l
131、t;/p><p> PreparedStatement pstmt2 = DB.prepareStmt(cconn, "update priority set r = ?, w = ? ,exe = ? where filename='"+ filename +"'" +" and username='"+ username +&q
132、uot;'");</p><p> pstmt2.setInt(1, r);</p><p> pstmt2.setInt(2, w);</p><p> pstmt2.setInt(3, exe);</p><p> pstmt2.executeUpdate();</p><p> p
133、out.println("權(quán)限修改成功");</p><p> DB.close(pstmt2);</p><p> DB.close(cstmt);</p><p> DB.close(cconn);</p><p><b> }</b></p><p><b&
134、gt; else{</b></p><p> System.out.println("nimeid ");</p><p> pout.println("權(quán)限修改失敗");</p><p><b> }</b></p><p><b> %>&
135、lt;/b></p><p><b> ?。?)用戶密碼修改</b></p><p><b> <%</b></p><p> request.setCharacterEncoding("GBK");</p><p> String username=(Stri
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 操作系統(tǒng)課程設(shè)計報告--多級文件系統(tǒng)
- 操作系統(tǒng)課程設(shè)計報告--多級文件系統(tǒng)
- 操作系統(tǒng)課程設(shè)計報告--多級文件系統(tǒng).doc
- 操作系統(tǒng)課程設(shè)計--多用戶多級目錄文件系統(tǒng)實(shí)現(xiàn)
- 操作系統(tǒng)課程設(shè)計--模擬文件系統(tǒng)
- 操作系統(tǒng)課程設(shè)計--樹形目錄文件系統(tǒng)
- 操作系統(tǒng)課程設(shè)計---多用戶多級目錄文件系統(tǒng)的實(shí)現(xiàn)
- 操作系統(tǒng)課程設(shè)計---多用戶多級目錄文件系統(tǒng)的實(shí)現(xiàn)
- 操作系統(tǒng)課程設(shè)計---文件系統(tǒng)的模擬
- 操作系統(tǒng)課程設(shè)計---模擬文件系統(tǒng)
- 操作系統(tǒng)課程設(shè)計---多用戶多級目錄文件系統(tǒng)的實(shí)現(xiàn)
- 操作系統(tǒng)課程設(shè)計-模擬文件系統(tǒng)
- 操作系統(tǒng)課程設(shè)計報告--linux二級文件系統(tǒng)設(shè)計
- 操作系統(tǒng)課程設(shè)計報告--虛擬文件系統(tǒng)的實(shí)現(xiàn)
- 操作系統(tǒng)課程設(shè)計二級文件系統(tǒng)
- 操作系統(tǒng)課程設(shè)計簡單文件系統(tǒng)的實(shí)現(xiàn)
- 操作系統(tǒng)課程設(shè)計二級文件系統(tǒng)
- 操作系統(tǒng)課程設(shè)計(文件系統(tǒng)管理)
- 操作系統(tǒng)課程設(shè)計--簡單文件系統(tǒng)的實(shí)現(xiàn)
- 操作系統(tǒng)課程設(shè)計----二級文件系統(tǒng)
評論
0/150
提交評論