一 环境:XP3+Oracle10g+MyEclipse6+(Tomcat)+JDK1.5
二 工程相关图片:
三 基本上参照之前示例修改得来,重点关注SimpleJdbcTemplate与JdbcTemplate用法
以下只列出比较重要的类
UserController.java
Java代码
- package com.liuzd.sj.web;
- import java.util.List;
- import javax.annotation.Resource;
- import javax.servlet.http.HttpServletRequest;
- import org.springframework.stereotype.Controller;
- import org.springframework.web.bind.annotation.PathVariable;
- import org.springframework.web.bind.annotation.RequestMapping;
- import org.springframework.web.bind.annotation.SessionAttributes;
- import org.springframework.web.servlet.ModelAndView;
- import com.liuzd.page.Page;
- import com.liuzd.sj.entity.User;
- import com.liuzd.sj.service.UserService;
- @Controller
- @RequestMapping("/user")
- @SessionAttributes("userList")
- public class UserController extends BaseController{
- private UserService userService;
- public UserService getUserService() {
- return userService;
- }
- @Resource
- public void setUserService(UserService userService) {
- this.userService = userService;
- }
- @RequestMapping("/userList")
- public ModelAndView userList(HttpServletRequest request){
- StringBuilder querySql = new StringBuilder();
- querySql.append("select * from users where 1=1 ");
- String oracleQuerySql = querySql.toString();
- //获取总条数
- Long totalCount = new Long(this.getUserService().pageCounts(oracleQuerySql));
- //设置分页对象
- Page page = executePage(request,oracleQuerySql,totalCount," id desc ");
- ModelAndView mv = new ModelAndView();
- //查询集合
-
List
users = this.getUserService().pageList(page.getQuerySql()); - mv.addObject("userList",users);
- mv.setViewName("userList");
- return mv;
- }
- @RequestMapping("/addUser")
- public ModelAndView addUser(HttpServletRequest request,User user){
- System.out.println("ADD USER: "+ user);
- this.userService.addUser(user);
- return userList(request);
- }
- @RequestMapping("/toAddUser")
- public String toAddUser(){
- return "addUser";
- }
- @RequestMapping("/delUser/{id}")
- public ModelAndView delUser(@PathVariable("id") String id,HttpServletRequest request){
- this.userService.delUser(new User().setId(id));
- return userList(request);
- }
- @RequestMapping("/getUser/{id}")
- public ModelAndView getUser(@PathVariable("id") String id){
- User user = this.userService.getUserById(new User().setId(id));
- ModelAndView mv = new ModelAndView("updateUser");
- mv.addObject("user",user);
- return mv;
- }
- @RequestMapping("/updateUser")
- public ModelAndView editUser(User user,HttpServletRequest request){
- System.out.println("编辑: "+user);
- this.userService.editUser(user);
- return userList(request);
- }
- }
package com.liuzd.sj.web; import java.util.List; import javax.annotation.Resource; import javax.servlet.http.HttpServletRequest; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.SessionAttributes; import org.springframework.web.servlet.ModelAndView; import com.liuzd.page.Page; import com.liuzd.sj.entity.User; import com.liuzd.sj.service.UserService; @Controller @RequestMapping("/user") @SessionAttributes("userList") public class UserController extends BaseController{ private UserService userService; public UserService getUserService() { return userService; } @Resource public void setUserService(UserService userService) { this.userService = userService; } @RequestMapping("/userList") public ModelAndView userList(HttpServletRequest request){ StringBuilder querySql = new StringBuilder(); querySql.append("select * from users where 1=1 "); String oracleQuerySql = querySql.toString(); //获取总条数 Long totalCount = new Long(this.getUserService().pageCounts(oracleQuerySql)); //设置分页对象 Page page = executePage(request,oracleQuerySql,totalCount," id desc "); ModelAndView mv = new ModelAndView(); //查询集合 List<user> users = this.getUserService().pageList(page.getQuerySql()); mv.addObject("userList",users); mv.setViewName("userList"); return mv; } @RequestMapping("/addUser") public ModelAndView addUser(HttpServletRequest request,User user){ System.out.println("ADD USER: "+ user); this.userService.addUser(user); return userList(request); } @RequestMapping("/toAddUser") public String toAddUser(){ return "addUser"; } @RequestMapping("/delUser/{id}") public ModelAndView delUser(@PathVariable("id") String id,HttpServletRequest request){ this.userService.delUser(new User().setId(id)); return userList(request); } @RequestMapping("/getUser/{id}") public ModelAndView getUser(@PathVariable("id") String id){ User user = this.userService.getUserById(new User().setId(id)); ModelAndView mv = new ModelAndView("updateUser"); mv.addObject("user",user); return mv; } @RequestMapping("/updateUser") public ModelAndView editUser(User user,HttpServletRequest request){ System.out.println("编辑: "+user); this.userService.editUser(user); return userList(request); } } </user>
BaseController.java
Java代码
- package com.liuzd.sj.web;
- import javax.servlet.http.HttpServletRequest;
- import com.liuzd.page.Page;
- import com.liuzd.page.PageState;
- import com.liuzd.page.PageUtil;
- /**
- *Title:
- *Description:
- *Copyright: Copyright (c) 2011
- *Company:http://liuzidong.iteye.com/
- *Makedate:2011-5-23 下午03:31:03
- * @author liuzidong
- * @version 1.0
- * @since 1.0
- *
- */
- public class BaseController {
- /**
- * oracel的三层分页语句
- * 子类在展现数据前,进行分页计算!
- * @param querySql 查询的SQL语句,未进行分页
- * @param totalCount 根据查询SQL获取的总条数
- * @param columnNameDescOrAsc 列名+排序方式 : ID DESC or ASC
- */
- protected Page executePage(HttpServletRequest request,String querySql,Long totalCount,String columnNameDescOrAsc){
- String oracleSql = PageUtil.createQuerySql(querySql,columnNameDescOrAsc);
- if(null == totalCount){
- totalCount = 0L;
- }
- /**页面状态,这个状态是分页自带的,与业务无关*/
- String pageAction = request.getParameter("pageAction");
- String value = request.getParameter("pageKey");
- /**获取下标判断分页状态*/
- int index = PageState.getOrdinal(pageAction);
- Page page = null;
- /**
- * index
- * 1 当首次调用时,分页状态类中没有值为 NULL 返回 -1
- * 2 当页面设置每页显示多少条: index=0,当每页显示多少条时,分页类要重新计算
- * */
- Page sessionPage = getPage(request);
- if(index 1){
- page = PageUtil.inintPage(oracleSql,totalCount,index,value,sessionPage);
- }else{
- page = PageUtil.execPage(index,value,sessionPage);
- }
- setSession(request,page);
- return page;
- }
- private Page getPage(HttpServletRequest request) {
- Page page = (Page)request.getSession().getAttribute(PageUtil.SESSION_PAGE_KEY);
- if(page == null){
- page = new Page();
- }
- return page;
- }
- private void setSession(HttpServletRequest request,Page page) {
- request.getSession().setAttribute(PageUtil.SESSION_PAGE_KEY,page);
- }
- }
package com.liuzd.sj.web; import javax.servlet.http.HttpServletRequest; import com.liuzd.page.Page; import com.liuzd.page.PageState; import com.liuzd.page.PageUtil; /** *Title: *Description: *Copyright: Copyright (c) 2011 *Company:http://liuzidong.iteye.com/ *Makedate:2011-5-23 下午03:31:03 * @author liuzidong * @version 1.0 * @since 1.0 * */ public class BaseController { /** * oracel的三层分页语句 * 子类在展现数据前,进行分页计算! * @param querySql 查询的SQL语句,未进行分页 * @param totalCount 根据查询SQL获取的总条数 * @param columnNameDescOrAsc 列名+排序方式 : ID DESC or ASC */ protected Page executePage(HttpServletRequest request,String querySql,Long totalCount,String columnNameDescOrAsc){ String oracleSql = PageUtil.createQuerySql(querySql,columnNameDescOrAsc); if(null == totalCount){ totalCount = 0L; } /**页面状态,这个状态是分页自带的,与业务无关*/ String pageAction = request.getParameter("pageAction"); String value = request.getParameter("pageKey"); /**获取下标判断分页状态*/ int index = PageState.getOrdinal(pageAction); Page page = null; /** * index <br>UserRowMapper.java <br> <p class="dp-highlighter"> </p><p class="bar"> </p><p class="tools">Java代码 </p> <ol class="dp-j"> <li> <span><span class="keyword">package</span><span> com.liuzd.sj.dao; </span></span> </li> <li> <span> </span> </li> <li> <span><span class="keyword">import</span><span> java.sql.ResultSet; </span></span> </li> <li> <span><span class="keyword">import</span><span> java.sql.SQLException; </span></span> </li> <li> <span> </span> </li> <li> <span><span class="keyword">import</span><span> org.springframework.jdbc.core.RowMapper; </span></span> </li> <li> <span> </span> </li> <li> <span><span class="keyword">import</span><span> com.liuzd.sj.entity.User; </span></span> </li> <li> <span> </span> </li> <li> <span><span class="keyword">public</span><span> </span><span class="keyword">class</span><span> UserRowMapper </span><span class="keyword">implements</span><span> RowMapper<user> { </user></span></span> </li> <li> <span> </span> </li> <li> <span> </span> </li> <li> <span> <span class="keyword">public</span><span> UserRowMapper(){} </span></span> </li> <li> <span> </span> </li> <li> <span> <span class="keyword">public</span><span> User mapRow(ResultSet rs, </span><span class="keyword">int</span><span> index) </span><span class="keyword">throws</span><span> SQLException { </span></span> </li> <li> <span> User user = <span class="keyword">new</span><span> User( </span></span> </li> <li> <span> rs.getString(<span class="string">"id"</span><span>), </span></span> </li> <li> <span> rs.getString(<span class="string">"name"</span><span>), </span></span> </li> <li> <span> rs.getString(<span class="string">"password"</span><span>), </span></span> </li> <li> <span> rs.getString(<span class="string">"address"</span><span>), </span></span> </li> <li> <span> rs.getString(<span class="string">"sex"</span><span>), </span></span> </li> <li> <span> rs.getInt(<span class="string">"age"</span><span>) </span></span> </li> <li> <span> ); </span> </li> <li> <span> <span class="keyword">return</span><span> user; </span></span> </li> <li> <span> } </span> </li> <li> <span>} </span> </li> </ol> <pre title="SpringMVC+JDBC:分页示例" class="java" style="DISPLAY: none" pre_index="2" source_url="http://liuzidong.iteye.com/blog/1067492" codeable_type="Blog" codeable_id="1067492" name="code">package com.liuzd.sj.dao; import java.sql.ResultSet; import java.sql.SQLException; import org.springframework.jdbc.core.RowMapper; import com.liuzd.sj.entity.User; public class UserRowMapper implements RowMapper<user> { public UserRowMapper(){} public User mapRow(ResultSet rs, int index) throws SQLException { User user = new User( rs.getString("id"), rs.getString("name"), rs.getString("password"), rs.getString("address"), rs.getString("sex"), rs.getInt("age") ); return user; } } </user>
UserDAOImpl.java
Java代码
- package com.liuzd.sj.dao.impl;
- import java.sql.PreparedStatement;
- import java.sql.SQLException;
- import java.util.List;
- import javax.annotation.Resource;
- import org.springframework.jdbc.core.BeanPropertyRowMapper;
- import org.springframework.jdbc.core.PreparedStatementSetter;
- import org.springframework.stereotype.Repository;
- import com.liuzd.sj.dao.UserDAO;
- import com.liuzd.sj.dao.UserRowMapper;
- import com.liuzd.sj.entity.User;
- @Repository("userDao")
- public class UserDAOImpl implements UserDAO
- {
- private static final String INSERT = "insert into users(id,name,age,sex,address,password)VALUES(?,?,?,?,?,?)";
- private static final String UPDATE = "update users set name=?,age=?,sex=?,address=?,password=? where id=?";
- private static final String GET = "select * from users where id=?";
- private static final String CHECK = "select count(1) from users where name=? and password=?";
- private static final String SELECT = "select * from users";
- private static final String DEL = "delete users where id=?";
- private org.springframework.jdbc.core.JdbcTemplate jdbcTemplate;
- public org.springframework.jdbc.core.JdbcTemplate getJdbcTemplate() {
- return jdbcTemplate;
- }
- @Resource
- public void setJdbcTemplate(
- org.springframework.jdbc.core.JdbcTemplate jdbcTemplate) {
- this.jdbcTemplate = jdbcTemplate;
- }
- public void addUser(final User user) {
- getJdbcTemplate().update(INSERT, new PreparedStatementSetter(){
- public void setValues(PreparedStatement ps)
- throws SQLException {
- int i = 0;
- ps.setString(++i, user.getId());
- ps.setString(++i, user.getName());
- ps.setInt(++i, user.getAge());
- ps.setString(++i,user.getSex());
- ps.setString(++i,user.getAddress());
- ps.setString(++i,user.getPassword());
- }
- });
- }
- public int checkUserExits(User user) {
- return getJdbcTemplate().queryForInt(CHECK, user.getName(),user.getPassword());
- }
- public void delUser(User user) {
- getJdbcTemplate().update(DEL, user.getId());
- }
- public void editUser(final User user) {
- getJdbcTemplate().update(UPDATE, new PreparedStatementSetter(){
- public void setValues(PreparedStatement ps)
- throws SQLException {
- int i = 0;
- ps.setString(++i, user.getName());
- ps.setInt(++i, user.getAge());
- ps.setString(++i,user.getSex());
- ps.setString(++i,user.getAddress());
- ps.setString(++i,user.getPassword());
- ps.setString(++i, user.getId());
- }
- });
- }
-
public List
getAllUser() { -
return getJdbcTemplate().query(SELECT, new BeanPropertyRowMapper
(User. class)); - }
- public User getUserById(User user) {
- return getJdbcTemplate().queryForObject(GET, new UserRowMapper(),user.getId());
- }
- public int pageCounts(String querySql) {
- return getJdbcTemplate().queryForInt("select count(1) from("+querySql+")");
- }
-
public List
pageList(String querySql) { - return getJdbcTemplate().query(querySql, new UserRowMapper());
- }
- }
package com.liuzd.sj.dao.impl; import java.sql.PreparedStatement; import java.sql.SQLException; import java.util.List; import javax.annotation.Resource; import org.springframework.jdbc.core.BeanPropertyRowMapper; import org.springframework.jdbc.core.PreparedStatementSetter; import org.springframework.stereotype.Repository; import com.liuzd.sj.dao.UserDAO; import com.liuzd.sj.dao.UserRowMapper; import com.liuzd.sj.entity.User; @Repository("userDao") public class UserDAOImpl implements UserDAO { private static final String INSERT = "insert into users(id,name,age,sex,address,password)VALUES(?,?,?,?,?,?)"; private static final String UPDATE = "update users set name=?,age=?,sex=?,address=?,password=? where id=?"; private static final String GET = "select * from users where id=?"; private static final String CHECK = "select count(1) from users where name=? and password=?"; private static final String SELECT = "select * from users"; private static final String DEL = "delete users where id=?"; private org.springframework.jdbc.core.JdbcTemplate jdbcTemplate; public org.springframework.jdbc.core.JdbcTemplate getJdbcTemplate() { return jdbcTemplate; } @Resource public void setJdbcTemplate( org.springframework.jdbc.core.JdbcTemplate jdbcTemplate) { this.jdbcTemplate = jdbcTemplate; } public void addUser(final User user) { getJdbcTemplate().update(INSERT, new PreparedStatementSetter(){ public void setValues(PreparedStatement ps) throws SQLException { int i = 0; ps.setString(++i, user.getId()); ps.setString(++i, user.getName()); ps.setInt(++i, user.getAge()); ps.setString(++i,user.getSex()); ps.setString(++i,user.getAddress()); ps.setString(++i,user.getPassword()); } }); } public int checkUserExits(User user) { return getJdbcTemplate().queryForInt(CHECK, user.getName(),user.getPassword()); } public void delUser(User user) { getJdbcTemplate().update(DEL, user.getId()); } public void editUser(final User user) { getJdbcTemplate().update(UPDATE, new PreparedStatementSetter(){ public void setValues(PreparedStatement ps) throws SQLException { int i = 0; ps.setString(++i, user.getName()); ps.setInt(++i, user.getAge()); ps.setString(++i,user.getSex()); ps.setString(++i,user.getAddress()); ps.setString(++i,user.getPassword()); ps.setString(++i, user.getId()); } }); } public List<user> getAllUser() { return getJdbcTemplate().query(SELECT, new BeanPropertyRowMapper<user>(User.class)); } public User getUserById(User user) { return getJdbcTemplate().queryForObject(GET, new UserRowMapper(),user.getId()); } public int pageCounts(String querySql) { return getJdbcTemplate().queryForInt("select count(1) from("+querySql+")"); } public List<user> pageList(String querySql) { return getJdbcTemplate().query(querySql, new UserRowMapper()); } } </user></user></user>
UserDAOImpl2.java
Java代码
- package com.liuzd.sj.dao.impl;
- import java.util.List;
- import java.util.Map;
- import javax.annotation.Resource;
- import org.springframework.jdbc.core.BeanPropertyRowMapper;
- import org.springframework.stereotype.Repository;
- import com.liuzd.sj.dao.UserDAO;
- import com.liuzd.sj.entity.User;
- import com.liuzd.util.BeanToMapUtil;
- @Repository("userDao2")
- public class UserDAOImpl2 implements UserDAO
- {
- private static final String INSERT = "insert into users(id,name,age,sex,address,password)VALUES(:id,:name,:age,:sex,:address,:password)";
- private static final String UPDATE = "update users set name=:name,age=:age,sex=:sex,address=:address,password=:password where id=:id";
- private static final String GET = "select * from users where id=?";
- private static final String CHECK = "select count(1) from users where name=? and password=?";
- private static final String SELECT = "select * from users";
- private static final String DEL = "delete users where id=?";
- private org.springframework.jdbc.core.simple.SimpleJdbcTemplate simpleJdbcTemplate;
- public org.springframework.jdbc.core.simple.SimpleJdbcTemplate getSimpleJdbcTemplate() {
- return simpleJdbcTemplate;
- }
- @Resource
- public void setSimpleJdbcTemplate(
- org.springframework.jdbc.core.simple.SimpleJdbcTemplate simpleJdbcTemplate) {
- this.simpleJdbcTemplate = simpleJdbcTemplate;
- }
- public void addUser(final User user) {
-
Map
userMap = BeanToMapUtil.beanToMap(user); - getSimpleJdbcTemplate().update(INSERT, userMap);
- }
- public int checkUserExits(User user) {
- return getSimpleJdbcTemplate().queryForInt(CHECK, user.getName(),user.getPassword());
- }
- public void delUser(User user) {
- getSimpleJdbcTemplate().update(DEL, user.getId());
- }
- public void editUser(final User user) {
-
Map
userMap = BeanToMapUtil.beanToMap(user); - getSimpleJdbcTemplate().update(UPDATE, userMap);
- }
-
public List
getAllUser() { -
return getSimpleJdbcTemplate().query(SELECT, new BeanPropertyRowMapper
(User. class)); - }
- public User getUserById(User user) {
-
return getSimpleJdbcTemplate().queryForObject(GET, new BeanPropertyRowMapper
(User. class),user.getId()); - }
- public int pageCounts(String querySql) {
- return getSimpleJdbcTemplate().queryForInt("select count(1) from("+querySql+")");
- }
-
public List
pageList(String querySql) { -
return getSimpleJdbcTemplate().query(querySql, new BeanPropertyRowMapper
(User. class)); - }
- }
package com.liuzd.sj.dao.impl; import java.util.List; import java.util.Map; import javax.annotation.Resource; import org.springframework.jdbc.core.BeanPropertyRowMapper; import org.springframework.stereotype.Repository; import com.liuzd.sj.dao.UserDAO; import com.liuzd.sj.entity.User; import com.liuzd.util.BeanToMapUtil; @Repository("userDao2") public class UserDAOImpl2 implements UserDAO { private static final String INSERT = "insert into users(id,name,age,sex,address,password)VALUES(:id,:name,:age,:sex,:address,:password)"; private static final String UPDATE = "update users set name=:name,age=:age,sex=:sex,address=:address,password=:password where id=:id"; private static final String GET = "select * from users where id=?"; private static final String CHECK = "select count(1) from users where name=? and password=?"; private static final String SELECT = "select * from users"; private static final String DEL = "delete users where id=?"; private org.springframework.jdbc.core.simple.SimpleJdbcTemplate simpleJdbcTemplate; public org.springframework.jdbc.core.simple.SimpleJdbcTemplate getSimpleJdbcTemplate() { return simpleJdbcTemplate; } @Resource public void setSimpleJdbcTemplate( org.springframework.jdbc.core.simple.SimpleJdbcTemplate simpleJdbcTemplate) { this.simpleJdbcTemplate = simpleJdbcTemplate; } public void addUser(final User user) { Map<string> userMap = BeanToMapUtil.beanToMap(user); getSimpleJdbcTemplate().update(INSERT, userMap); } public int checkUserExits(User user) { return getSimpleJdbcTemplate().queryForInt(CHECK, user.getName(),user.getPassword()); } public void delUser(User user) { getSimpleJdbcTemplate().update(DEL, user.getId()); } public void editUser(final User user) { Map<string> userMap = BeanToMapUtil.beanToMap(user); getSimpleJdbcTemplate().update(UPDATE, userMap); } public List<user> getAllUser() { return getSimpleJdbcTemplate().query(SELECT, new BeanPropertyRowMapper<user>(User.class)); } public User getUserById(User user) { return getSimpleJdbcTemplate().queryForObject(GET, new BeanPropertyRowMapper<user>(User.class),user.getId()); } publ</user></user></user></string></string>

ACID屬性包括原子性、一致性、隔離性和持久性,是數據庫設計的基石。 1.原子性確保事務要么完全成功,要么完全失敗。 2.一致性保證數據庫在事務前後保持一致狀態。 3.隔離性確保事務之間互不干擾。 4.持久性確保事務提交後數據永久保存。

MySQL既是數據庫管理系統(DBMS),也與編程語言緊密相關。 1)作為DBMS,MySQL用於存儲、組織和檢索數據,優化索引可提高查詢性能。 2)通過SQL與編程語言結合,嵌入在如Python中,使用ORM工具如SQLAlchemy可簡化操作。 3)性能優化包括索引、查詢、緩存、分庫分錶和事務管理。

MySQL使用SQL命令管理數據。 1.基本命令包括SELECT、INSERT、UPDATE和DELETE。 2.高級用法涉及JOIN、子查詢和聚合函數。 3.常見錯誤有語法、邏輯和性能問題。 4.優化技巧包括使用索引、避免SELECT*和使用LIMIT。

MySQL是一種高效的關係型數據庫管理系統,適用於存儲和管理數據。其優勢包括高性能查詢、靈活的事務處理和豐富的數據類型。實際應用中,MySQL常用於電商平台、社交網絡和內容管理系統,但需注意性能優化、數據安全和擴展性。

SQL和MySQL的關係是標準語言與具體實現的關係。 1.SQL是用於管理和操作關係數據庫的標準語言,允許進行數據的增、刪、改、查。 2.MySQL是一個具體的數據庫管理系統,使用SQL作為其操作語言,並提供高效的數據存儲和管理。

InnoDB使用redologs和undologs確保數據一致性和可靠性。 1.redologs記錄數據頁修改,確保崩潰恢復和事務持久性。 2.undologs記錄數據原始值,支持事務回滾和MVCC。

EXPLAIN命令的關鍵指標包括type、key、rows和Extra。 1)type反映查詢的訪問類型,值越高效率越高,如const優於ALL。 2)key顯示使用的索引,NULL表示無索引。 3)rows預估掃描行數,影響查詢性能。 4)Extra提供額外信息,如Usingfilesort提示需要優化。

Usingtemporary在MySQL查詢中表示需要創建臨時表,常見於使用DISTINCT、GROUPBY或非索引列的ORDERBY。可以通過優化索引和重寫查詢避免其出現,提升查詢性能。具體來說,Usingtemporary出現在EXPLAIN輸出中時,意味著MySQL需要創建臨時表來處理查詢。這通常發生在以下情況:1)使用DISTINCT或GROUPBY時進行去重或分組;2)ORDERBY包含非索引列時進行排序;3)使用複雜的子查詢或聯接操作。優化方法包括:1)為ORDERBY和GROUPB


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

SublimeText3漢化版
中文版,非常好用

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),