ASP.NET WEB——项目创建与文件上传操作

简介: ASP.NET WEB——项目创建与文件上传操作

ASP.NET WEB——项目创建与文件上传操作


 

前言

ASP.NET WEB是一门非常简单的课程内容,我们大概用三章的内容来包含所有的知识点,三章分为

1、ASP.NET WEB项目创建与文件上传操作

2、ASP.NET WEB项目中Cookie与Session的用法

3、ASP.NET WEB项目中GridView与Repeater数据绑定控件的用法

分为三章,基本上将具体的用法讲解完毕,配套的【Repeater】的基础项目视频包含【数据库CRUD操作】让你快速上手,解决你考试的后顾之忧。

环境

系统环境:【win11】

开发工具:【Visual Studio 2017】

数据库:【SQLServer 2019】


项目创建

建议使用最新版本的2022活2023版本,这里操作是类似的,但是我这机房最高能使用到2017版本,不然就太大了运行起来经常崩溃。

我们选择创建【Web窗体】项目

创建完成后可以看到的页面。

点击【调试】->【运行(不调试)】

运行效果

表单校验

表单校验这个我就讲两个,一个是【非空验证】另外一个是【比较验证】,分别用于【文本是否为空验证】以及【两次密码比较】的情景。

创建自定义Web窗体

1、在项目上点击【鼠标右键】,注意,这里一定是在项目上,否则你找不到添加【Web窗体】的选项。

2、【添加】->【Web窗体】

3、输入窗体名称,我们这里先输入一个【Login】做测试

创建一个登陆页面

创建的窗体实际上是多个文件

我们在页面上进行绘制操作,在后台cs文件中写对应的控制函数。

登陆窗体示例

前台

这里要注意【OnClick="Unnamed_Click"】这个函数一定要有后台的对应函数,否则肯定报错。

<p>
    <asp:TextBox runat="server" ID="userName"
        placeholder="请输入用户名"></asp:TextBox>
</p>
<p>
    <asp:TextBox runat="server" ID="pwd"
        placeholder="请输入密码"></asp:TextBox>
</p>
<p>
    <asp:Button runat="server" OnClick="Unnamed_Click" Text="登陆"/>
</p>

页面效果:

后台交互

这里我就做了一个后台的非空判断和账号密码判断。

protected void Unnamed_Click(object sender, EventArgs e)
{
    string userName = this.userName.Text;
    string pwd = this.pwd.Text;
    if (
        string.IsNullOrEmpty(userName)
        ||
        string.IsNullOrEmpty(pwd)
        ) {
        Response.Write("<script>alert('账号面面不能为空!')</script>");
        return;
    }
    if (userName == "admin" && pwd == "abcd1234")
    {
        Response.Write("<script>alert('登陆成功!')</script>");
    }
    else {
        Response.Write("<script>alert('登陆失败!')</script>");
    }
}

前台验证

我们在后台添加了验证,但是为了保障程序肯定没问题,所以我们在前台也加上非空验证。

<p>
    <asp:TextBox runat="server" ID="userName"
        placeholder="请输入用户名"></asp:TextBox>
    <asp:RequiredFieldValidator runat="server" 
        ControlToValidate="userName"
        ErrorMessage="用户名不能为空"
        ForeColor="Red"
        ></asp:RequiredFieldValidator>
</p>
<p>
    <asp:TextBox runat="server" ID="pwd"
        placeholder="请输入密码"></asp:TextBox>
    <asp:RequiredFieldValidator runat="server" 
        ControlToValidate="pwd"
        ErrorMessage="用户密码不能为空"
        ForeColor="Red"
        ></asp:RequiredFieldValidator>
</p>
<p>
    <asp:Button runat="server" OnClick="Unnamed_Click" Text="登陆"/>
</p>

测试效果:

登陆效果:

添加密码双次输入验证

前台源码:

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Login.aspx.cs" Inherits="Demo_1.Login" %>
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title></title>
</head>
<body>
    <form id="form1" runat="server">
        <div>
            <p>
                <asp:TextBox runat="server" ID="userName"
                    placeholder="请输入用户名"></asp:TextBox>
                <asp:RequiredFieldValidator runat="server"
                    ControlToValidate="userName"
                    ErrorMessage="用户名不能为空"
                    ForeColor="Red"></asp:RequiredFieldValidator>
            </p>
            <p>
                <asp:TextBox runat="server" ID="pwd"
                    placeholder="请输入密码"></asp:TextBox>
                <asp:RequiredFieldValidator runat="server"
                    ControlToValidate="pwd"
                    ErrorMessage="用户密码不能为空"
                    ForeColor="Red"></asp:RequiredFieldValidator>
            </p>
            <p>
                <asp:TextBox runat="server" ID="pwd1"
                    placeholder="请输入密码"></asp:TextBox>
                <asp:RequiredFieldValidator runat="server"
                    ControlToValidate="pwd"
                    ErrorMessage="用户密码不能为空"
                    ForeColor="Red"></asp:RequiredFieldValidator>
                <asp:CompareValidator runat="server"
                    ErrorMessage="两次密码不同"
                    ControlToValidate="pwd"
                    ControlToCompare="pwd1"
                    ForeColor="Red"
                    ></asp:CompareValidator>
            </p>
            <p>
                <asp:Button runat="server" OnClick="Unnamed_Click" Text="登陆" />
            </p>
        </div>
    </form>
</body>
</html>

实际效果:

文件上传

创建文件上传页面

前端代码:

<asp:FileUpload runat="server" ID="file"/>
<hr />
<asp:Button runat="server" OnClick="Unnamed_Click" Text="文件上传"/>
<hr />
<asp:Image runat="server" ID="showImg" Width="400" Height="200"/>

项目中创建保存图片文件夹【imgs】

创建效果:

后台代码:

/// <summary>
/// 上传文件
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void Unnamed_Click(object sender, EventArgs e)
{
    //获取文件后缀名
    string ext = System.IO.Path.GetExtension(this.file.FileName);
    //组合新文件名
    string newFileName = Guid.NewGuid().ToString("N") + ext;
    //拼接完整的服务保存路径
    string saveUrl = Server.MapPath("/imgs/") + newFileName;
    //保存图片
    this.file.SaveAs(saveUrl);
    //显示图片
    this.showImg.ImageUrl = "/imgs/" + newFileName;
}

上传操作效果:

 

相关文章
|
1月前
|
XML JSON API
ServiceStack:不仅仅是一个高性能Web API和微服务框架,更是一站式解决方案——深入解析其多协议支持及简便开发流程,带您体验前所未有的.NET开发效率革命
【10月更文挑战第9天】ServiceStack 是一个高性能的 Web API 和微服务框架,支持 JSON、XML、CSV 等多种数据格式。它简化了 .NET 应用的开发流程,提供了直观的 RESTful 服务构建方式。ServiceStack 支持高并发请求和复杂业务逻辑,安装简单,通过 NuGet 包管理器即可快速集成。示例代码展示了如何创建一个返回当前日期的简单服务,包括定义请求和响应 DTO、实现服务逻辑、配置路由和宿主。ServiceStack 还支持 WebSocket、SignalR 等实时通信协议,具备自动验证、自动过滤器等丰富功能,适合快速搭建高性能、可扩展的服务端应用。
100 3
|
13天前
|
JavaScript 前端开发 开发工具
web项目规范配置(husky、eslint、lint-staged、commit)
通过上述配置,可以确保在Web项目开发过程中自动进行代码质量检查和规范化提交。Husky、ESLint、lint-staged和Commitlint共同作用,使得每次提交代码之前都会自动检查代码风格和语法问题,防止不符合规范的代码进入代码库。这不仅提高了代码质量,还保证了团队协作中的一致性。希望这些配置指南能帮助你建立高效的开发流程。
31 5
|
20天前
|
JavaScript 前端开发 数据安全/隐私保护
Web开发者必看:手把手教你如何轻松播放m3u8流地址,解锁视频播放新技能,让你的项目更上一层楼!
【10月更文挑战第23天】随着互联网技术的发展,m3u8格式因良好的兼容性和高压缩率被广泛用于网络流媒体传输。本文介绍如何在Web端播放m3u8流地址,包括引入视频播放器(如Video.js)、创建播放器容器、初始化播放器及播放m3u8流的具体步骤。此外,还涉及处理加密m3u8流的示例。
70 1
|
28天前
|
JSON 搜索推荐 API
Python的web框架有哪些?小项目比较推荐哪个?
【10月更文挑战第15天】Python的web框架有哪些?小项目比较推荐哪个?
47 1
|
1月前
|
前端开发 JavaScript API
惊呆了!学会AJAX与Fetch API,你的Python Web项目瞬间高大上!
在Web开发领域,AJAX与Fetch API是提升交互体验的关键技术。AJAX(Asynchronous JavaScript and XML)作为异步通信的先驱,通过XMLHttpRequest对象实现了局部页面更新,提升了应用流畅度。Fetch API则以更现代、简洁的方式处理HTTP请求,基于Promises提供了丰富的功能。当与Python Web框架(如Django、Flask)结合时,这两者能显著增强应用的响应速度和用户体验,使项目更加高效、高大上。
50 2
|
2月前
|
开发框架 监控 前端开发
在 ASP.NET Core Web API 中使用操作筛选器统一处理通用操作
【9月更文挑战第27天】操作筛选器是ASP.NET Core MVC和Web API中的一种过滤器,可在操作方法执行前后运行代码,适用于日志记录、性能监控和验证等场景。通过实现`IActionFilter`接口的`OnActionExecuting`和`OnActionExecuted`方法,可以统一处理日志、验证及异常。创建并注册自定义筛选器类,能提升代码的可维护性和复用性。
|
2月前
|
开发框架 .NET 中间件
ASP.NET Core Web 开发浅谈
本文介绍ASP.NET Core,一个轻量级、开源的跨平台框架,专为构建高性能Web应用设计。通过简单步骤,你将学会创建首个Web应用。文章还深入探讨了路由配置、依赖注入及安全性配置等常见问题,并提供了实用示例代码以助于理解与避免错误,帮助开发者更好地掌握ASP.NET Core的核心概念。
93 3
|
2月前
|
前端开发 Python
前后端分离的进化:Python Web项目中的WebSocket实时通信解决方案
在现代Web开发领域,前后端分离已成为一种主流架构模式,它促进了开发效率、提升了应用的可维护性和可扩展性。随着实时数据交互需求的日益增长,WebSocket作为一种在单个长连接上进行全双工通讯的协议,成为了实现前后端实时通信的理想选择。在Python Web项目中,结合Flask框架与Flask-SocketIO库,我们可以轻松实现WebSocket的实时通信功能。
56 2
|
2月前
|
开发框架 前端开发 .NET
VB.NET中如何利用ASP.NET进行Web开发
在VB.NET中利用ASP.NET进行Web开发是一个常见的做法,特别是在需要构建动态、交互式Web应用程序时。ASP.NET是一个由微软开发的开源Web应用程序框架,它允许开发者使用多种编程语言(包括VB.NET)来创建Web应用程序。
58 5
|
1月前
|
监控 Java Maven
springboot学习二:springboot 初创建 web 项目、修改banner、热部署插件、切换运行环境、springboot参数配置,打包项目并测试成功
这篇文章介绍了如何快速创建Spring Boot项目,包括项目的初始化、结构、打包部署、修改启动Banner、热部署、环境切换和参数配置等基础操作。
125 0