AWVS漏洞测试-02节-添加一个简单的新闻系统
实现一个简单的新闻发布系统
有登录 注册 添加新闻 浏览新闻 评论新闻 新闻列表 这些基本功能
使用asp.net webform
首先是登录页

protected void Button1_Click(object sender, EventArgs e)
{
string name = this.TextBox1.Text.Trim();
string pwd = this.TextBox2.Text.Trim();
if (name=="bamn"&&pwd=="")
{
Session["user"] = name;
Response.Redirect("/");
}
Response.Write("账号或者密码不正确");
Response.End();
}
上面是按钮事件,简单判断密码和账号,登录成功写入session,跳转到首页,否则输入提示
然后我们添加注册页

protected void Button1_Click(object sender, EventArgs e)
{
string name = this.TextBox1.Text.Trim();
string pwd = this.TextBox2.Text.Trim();
string pwd2 = this.TextBox3.Text.Trim();
if (name == "" || pwd == "")
{
ShowInfo("输入不正确");
}
else if (pwd != pwd2)
{
ShowInfo("两次密码一样");
}
//正常开发的话,这里面应该是添加到数据库中的
//我们这里就简单当做保存了 跳转到登录页
Response.Redirect("/");
} private void ShowInfo(string info)
{
Response.Write(info);
Response.End();
}
然后就是发布新闻页了

protected void Button1_Click(object sender, EventArgs e)
{
//先判断输入是否正确
//我们这里由于没有数据库,所以这里就使用配置文件 序列化
string content = this.TextBox1.Text.Trim();
string title = this.TextBox2.Text.Trim();
if (content == "" || title == "")
{
ShowInfo("输入不正确");
}
News news = new News();
news.Content = content;
news.Title = title;
string guid = System.Guid.NewGuid().ToString();
news.Guid = guid;
news.Date = DateTime.Now.ToString();
string json = new JavaScriptSerializer().Serialize(news);
string path = Server.MapPath("~/") + "jsons\\" + guid + ".json" ;
File.WriteAllText(path, json);
Response.Redirect("/");
} public class News
{
public string Date { set; get; }
public string Title { set; get; }
public string Content { set; get; }
public string Guid { get; set; }
}
我们这里是通过序列化保存成json文件,到jsons的目录下面
然后就是到首页了,首页我们现实列表
<form id="form1" runat="server">
<div>
<asp:Repeater ID="RepeaterNews" runat="server">
<ItemTemplate>
<div class="movies">
<a href="/view.aspx?guid=<%#Eval("Guid") %>"><%#Eval("Title") %></a>
<label><%#Eval("Date") %></label>
</div>
</ItemTemplate>
</asp:Repeater>
</div>
</form> protected void Page_Load(object sender, EventArgs e)
{
RepeaterNews.DataSource = GetNewList();
RepeaterNews.DataBind();
} private List<News> GetNewList()
{
//获取文件列表
string[] files = Directory.GetFiles(Server.MapPath("~/") + "jsons\\");
List<News> newsList = new List<News>();
for (int i = ; i < files.Count(); i++)
{
string content = File.ReadAllText(files[i]);
News news = new JavaScriptSerializer().Deserialize<News>(content);
newsList.Add(news);
}
return newsList;
}

下面再到详细页
<form id="form1" runat="server">
<div>
<asp:Label ID="LabelTitle" runat="server"></asp:Label><br />
<asp:Label ID="LabelContent" runat="server"></asp:Label><br />
<asp:Label ID="LabelDate" runat="server"></asp:Label><br />
</div>
</form> protected void Page_Load(object sender, EventArgs e)
{
string guid = Request.QueryString["guid"];
string path = Server.MapPath("~/") + "jsons\\" + guid + ".json";
string json = File.ReadAllText(path);
News news = new JavaScriptSerializer().Deserialize<News>(json);
this.LabelContent.Text = news.Content;
this.LabelTitle.Text = news.Title;
this.LabelDate.Text = news.Date;
}

到现在为止,我们基本实现了一个新闻发布 列表 预览 注册 登录的简单功能
本集和AWVS没什么关系,主要是我们想通过这个程序来,测试我们的AWVS漏洞功能
希望对你有帮助,更多课程可以访问www.bamn.cn
AWVS漏洞测试-02节-添加一个简单的新闻系统的更多相关文章
- AWVS漏洞测试-03节-添加扫描项目
http://localhost:9660 我们要扫描这个页面 点击左上角的New Scan,在Scan Single哪里输入要扫描的网站地址,可以是本地地址 然后选择下一步 Next 这里我们可以配 ...
- AWVS漏洞测试-01节-AWVS的主要作用
AWVS漏洞工具简单介绍 AWVS全称: Acunetix Web Vulnerability Scanner 中文翻译就是:Acunetix网站攻击扫描器 扫描网站漏洞,通过网络爬虫Crawler的 ...
- 一个简单的CS系统打包过程图文版
一个简单的CS系统打包过程图文版 1. 打包内容 1.1. 此次打包的要求和特点 主工程是一个CS系统: 此CS系统运行的先决条件是要有.Net Framework 3.5: 主工程安装完成 ...
- Linux下一个简单的日志系统的设计及其C代码实现
1.概述 在大型软件系统中,为了监测软件运行状况及排查软件故障,一般都会要求软件程序在运行的过程中产生日志文件.在日志文件中存放程序流程中的一些重要信息, 包括:变量名称及其值.消息结构定义.函数返回 ...
- Linux内核分析— —构造一个简单的Linux系统MenuOS(20135213林涵锦)
Linux内核分析— —构造一个简单的Linux系统MenuOS 实验内容 Linux内核的启动过程,从start_kernel到init进程启动 使用实验楼的虚拟机打开shell cd LinuxK ...
- Linux第三周学习总结——构造一个简单的Linux系统MenuOS
第三周学习总结--构造一个简单的Linux系统MenuOS 作者:刘浩晨 [原创作品转载请注明出处] <Linux内核分析>MOOC课程http://mooc.study.163.com/ ...
- Linux内核设计第三周——构造一个简单的Linux系统
Linux内核设计第三周 ——构造一个简单的Linux系统 一.知识点总结 计算机三个法宝: 存储程序计算机 函数调用堆栈 中断 操作系统两把宝剑: 中断上下文的切换 进程上下文的切换 linux内核 ...
- 《Linux内核分析》第三周 构建一个简单的Linux系统MenuOS
[刘蔚然 原创作品转载请注明出处 <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000] WEEK THREE ...
- 第三节 构造一个简单的Linux系统MenuOS——20135203齐岳
第三节 构造一个简单的Linux系统MenuOS By 20135203齐岳 Linux内核源代码 arch/ 支持不同cpu的源代码 Documentations/ 文档存储 init/ 内核启动相 ...
随机推荐
- vsftpd的主动模式与被动模式
好不容易配置好了vsftpd服务,在CentOS本机测试没有问题,但是在我的Windows机器上使用FlashFXP连接的时候却出问题了: 我虽然知道FTP存在两种模式:PORT(主动)模式.PASV ...
- linux samba 服务器 简单配置
1. rpm -qa|grep samba 查看是否有samba 2.使用yum -y install samba 安装samba 服务 进入/etc/samba/ 使用vi smb.conf 修改配 ...
- mysql 授权
cd /usr/local/mysql/bin/grant all privileges on *.* to 'root'@'%' identified by '12345678';flush pri ...
- 3.SRS文档
1.功能需求 本程序的使用者为局域网用户.程序实现的主要功能是局域网的常见格式的文件的传 输.其用例图如图1.本程序可通过可视化操作界面实现一对多的文件传输. 1.1模块分析 为实现局域网文件传输, ...
- Devexpress GridView内嵌dx:ASPxGridLookup取得控件值乱跳解决方案
一 页面嵌入ASPxGridLookup控件 <dx:ASPxGridView ID="gridDetail" runat="server" ...
- mongodb(二) 安装和使用
mongodb的安装和使用 最近的项目需要使用到mongodb,从而开始熟悉nosql,有了本篇文章,记录和方便他人. mongodb的安装 下载地址:http://www.mongodb.org/d ...
- [ACM_水题] 不要62(hdu oj 2089, 不含62和4的数字统计)
Problem Description 杭州人称那些傻乎乎粘嗒嗒的人为62(音:laoer).杭州交通管理局经常会扩充一些的士车牌照,新近出来一个好消息,以后上牌照,不再含有不吉利的数字了,这样一来, ...
- CheckStyle, 强制你遵循编码规范
如今代码静态检查越来越重要,已经成为构建高质量软件的不可或缺的一个验证步骤.如果你使用的是java语言,那么CheckStyle则是一个利器. CheckStyle能够帮助程序员检查代码是否符合制定的 ...
- C#与数据库访问技术总结(十七)
使用DataSet对象访问数据库 当对DataSet对象进行操作时,DataSet对象会产生副本,所以对DataSet里的数据进行编辑操作不会直接对数据库产生影响,而是将DataRow的状态设置为ad ...
- [Python爬虫] Selenium获取百度百科旅游景点的InfoBox消息盒
前面我讲述过如何通过BeautifulSoup获取维基百科的消息盒,同样可以通过Spider获取网站内容,最近学习了Selenium+Phantomjs后,准备利用它们获取百度百科的旅游景点消息盒(I ...