zoukankan      html  css  js  c++  java
  • 20145234黄斐《网络对抗技术》实验八、Web基础

    Apache

    • 先通过apachectl start命令开启Apach,使用netstat -aptn命令查看端口占用:

    • 因为端口号80已经被占用(上次实验设置的),所以先修改/etc/apache2/ports.conf里的端口为5234后重新开启:

    • 可以在浏览器中输入localhost:5234来检查是否正常开启,这里可以看到打开了上次实验的网页,开启正常:

    简单的表单网页

    • 在/var/www/html即上次实验网页所在的位置编写一个有表单的网页:

    • 在浏览器中打开localhost:5234/5234.html(颜色可以查一下自己喜欢的颜色的色值写进去):

    • 点击提交会把表单提交到指定页面,因为还没有编写php文件,所以提交后找不到页面:

    javascript

    • 相关概念:JavaScript是一种广泛用于客户端Web开发的脚本语言,常用来给HTML网页添加动态功能,比如响应用户的各种操作。
    • 文档对象模型(Document Object Model,简称DOM,是W3C组织推荐的处理可扩展标志语言的标准编程接口。
    • 编写验证用户名和密码的规则:(比如用户名和密码不能为空)

    PHP测试

    • PHP,一个嵌套的缩写名称,是英文超级文本预处理语言(PHP:Hypertext Preprocessor)的缩写。PHP 是一种 HTML 内嵌式的语言,PHP与微软的ASP颇有几分相似,都是一种在服务器端执行的嵌入HTML文档的脚本语言,语言的风格有类似于C语言,现在被很多的网站编程人员广泛的运用。

    • 一个简单的php测试代码:

    • 打开localhost:5234/5234php.php:

    MySQL

    • 使用命令/etc/init.d/mysql start打开mysql服务
    • 输入mysql -u root -p,并根据提示输入密码,默认密码为p@ssw0rd,进入MySQL:

    • 可以使用命令show databases;查看信息(分号不可以漏掉,分号代表命令的结束):

    • 如果想修改密码可以:
      ·输入use mysql;,选择mysql数据库
      ·输入select user, password, host from user;,mysql库中的user表中存储着用户名、密码与权限
      ·输入UPDATE user SET password=PASSWORD("新密码") WHERE user='root';
      ·输入flush privileges;,更新权限
      ·输入quit退出

    • 重新登录就可以发现密码修改成功

    创建新表

    • 使用如下两条命令可以建立新表:
    CREATE SCHEMA `库表的名称`;
    CREATE TABLE `库表的名称`.`users` (
     `userid` INT NOT NULL COMMENT '',
     `username` VARCHAR(45) NULL COMMENT '',
     `password` VARCHAR(256) NULL COMMENT '',
     `enabled` VARCHAR(5) NULL COMMENT '',
     PRIMARY KEY (`userid`) COMMENT '');

    • 向表中添加内容:

    use 刚刚建立的库表的表名

    insert into users(userid,username,password,enabled) values(1,'用户id',password("用户密码"),"TRUE");

    • 现在再查看信息就可以看到新建表:

    php+mysql编写网页

    • 网页的登录页面:

    • 实现与数据库链接的php页面:

    • 网页界面:

    • 输入登录信息,登录成功:

    • 如果错误的信息则不成功:

     

    SQL注入

    • SQL本是查询语句,可以实现对数据库的增、删、改、查等操作,是操作数据库数据的直接手段,但是SQL语句是存在缺陷的,根据前文中SQL的编写过程可以体会,当输入某些特定格式的字符串的时候,会利用语法避开一些检查,通常也叫这样的密码为“万能密码”

    获取权限

    • 在用户名输入框中输入' or 1=1#,密码随便输入,这时候的合成后的SQL查询语句为select * from info where usrname='' or 1=1#' and password='' and type='',#相当于注释符,会把后面的内容都注释掉,而1=1是永真式,所以这个条件肯定恒成立,所以能够成功登陆:

    • 只要弄懂sql语句查询语法或者上网搜索,就可以找到很多这样的万能密码

    增加权限:

    • 通过sql注入保存用户名密码到数据库:';insert into users(userid,username,password,enabled) values(5234,'huangyunguang',password("20145234"),"TRUE");#

    • 重新登录,输入新账户,登录成功

    XSS攻击

    • XSS攻击:跨站脚本攻击(Cross Site Scripting),为不和层叠样式表(Cascading Style Sheets, CSS)的缩写混淆。故将跨站脚本攻击缩写为XSS。XSS是一种经常出现在web应用中的计算机安全漏洞,它允许恶意web用户将代码植入到提供给其它用户使用的页面中。比如这些代码包括HTML代码和客户端脚本。攻击者利用XSS漏洞旁路掉访问控制——例如同源策略(same origin policy)。这种类型的漏洞由于被骇客用来编写危害性更大的phishing攻击而变得广为人知。对于跨站脚本攻击,黑客界共识是:跨站脚本攻击是新型的“缓冲区溢出攻击“,而JavaScript是新型的“ShellCode”。

    • 输入<img src="123.jpg" />20145234</a>来读取网页目录下的图片:

    图片有点问题显示不出来 ,但还是有图片的图标

    会话管理

    这一步没做出来

  • 相关阅读:
    BZOJ1066: [SCOI2007]蜥蜴
    BZOJ1934: [Shoi2007]Vote 善意的投票
    BZOJ2321: [BeiJing2011集训]星器
    BZOJ1076: [SCOI2008]奖励关
    BZOJ1821: [JSOI2010]Group 部落划分 Group
    BZOJ3038: 上帝造题的七分钟2
    NOIP2017滚粗记
    BZOJ1087: [SCOI2005]互不侵犯King
    BZOJ1085: [SCOI2005]骑士精神
    BZOJ1295: [SCOI2009]最长距离
  • 原文地址:https://www.cnblogs.com/taigenzhenjun/p/6833372.html
Copyright © 2011-2022 走看看