mvc控制器
控制器
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using System.Net.Http;
using Newtonsoft.Json;
using WebApplication1.Models;
using Webdiyer.WebControls.Mvc;
namespace WebApplication1.Controllers
{
public class showController : Controller
{
// GET: show
/// <summary>
/// 查询 显示 分页
/// </summary>
/// <param name="name"></param>
/// <param name="type"></param>
/// <param name="pageIndex"></param>
/// <returns></returns>
public ActionResult Index(string name, int type = 0, int pageIndex=1)
{
//获取全部数据
Uri uri = new Uri("http://localhost:1036/"); //api的地址
HttpClient client = new HttpClient();
client.BaseAddress = uri;//报头
client.DefaultRequestHeaders.Accept.Add(new System.Net.Http.Headers.MediaTypeWithQualityHeaderValue("application/json"));
HttpResponseMessage message = client.GetAsync("actionApi/showApi/show?name=" + name + "&type=" + type).Result;
List<Allcs> tt = new List<Allcs>();//显示在集合里
if (message.IsSuccessStatusCode)
{
string pp = message.Content.ReadAsStringAsync().Result;
tt = JsonConvert.DeserializeObject<List<Allcs>>(pp);//反序列化
}
client.Dispose();//释放
//下拉
Uri uris = new Uri("http://localhost:1036/");
HttpClient clients = new HttpClient();
clients.BaseAddress = uris;
clients.DefaultRequestHeaders.Accept.Add(new System.Net.Http.Headers.MediaTypeWithQualityHeaderValue("application/json"));
HttpResponseMessage mess = clients.GetAsync("actionApi/showApi/xia").Result;
List<stutype> tts = new List<stutype>();
if (mess.IsSuccessStatusCode)
{
string pp = mess.Content.ReadAsStringAsync().Result;
tts= JsonConvert.DeserializeObject<List<stutype>>(pp);
SelectList list = new SelectList(tts, "Sids", "Sname");
ViewBag.xia = list;
}
clients.Dispose();//释放
return View(tt.ToList().ToPagedList(pageIndex,2)); //显示 反页
}
/// <summary>
/// 添加
/// </summary>
/// <returns></returns>
public ActionResult add()
{
//下拉
Uri uris = new Uri("http://localhost:1036/");
HttpClient clients = new HttpClient();
clients.BaseAddress = uris;
clients.DefaultRequestHeaders.Accept.Add(new System.Net.Http.Headers.MediaTypeWithQualityHeaderValue("application/json"));
HttpResponseMessage mess = clients.GetAsync("actionApi/showApi/xia").Result;
List<stutype> tts = new List<stutype>();
if (mess.IsSuccessStatusCode)
{
string pp = mess.Content.ReadAsStringAsync().Result;
tts = JsonConvert.DeserializeObject<List<stutype>>(pp);
SelectList list = new SelectList(tts, "Sids", "Sname");
ViewBag.xia = list;
}
clients.Dispose();//释放
return View();
}
/// <summary>
/// 添加
/// </summary>
/// <param name="model"></param>
/// <returns></returns>
[HttpPost]
public ActionResult add(stuM model)
{
//添加图片 img是一个新建的文件夹
var file = Request.Files["tu"];
var names = "/img/" + file.FileName;
file.SaveAs(Server.MapPath(names));
//添加mvc里的类
Allcs m = new Allcs();
m.men = model.men;
m.name = model.name;
m.number = model.number;
m.shijian = model.shijian;
m.Sids = model.Sids;
m.tu = names;
//传值
Uri uri = new Uri("http://localhost:1036/");
HttpClient client = new HttpClient();
client.BaseAddress = uri;
client.DefaultRequestHeaders.Accept.Add(new System.Net.Http.Headers.MediaTypeWithQualityHeaderValue("application/json"));
HttpContent cont = new StringContent(JsonConvert.SerializeObject(m));//把类序列化
cont.Headers.ContentType = new System.Net.Http.Headers.MediaTypeHeaderValue("application/json");
var pp = "";
HttpResponseMessage mesa = client.PostAsync("actionApi/showApi/add", cont).Result;//执行到api
if (mesa.IsSuccessStatusCode)//判断
{
pp = mesa.Content.ReadAsStringAsync().Result;
}
if (Convert.ToInt32(pp) > 0)
{
return Content("<script>alert('添加成功');location.href = '/show/Index';</script>");
}
else
{
return Content("<script>alert('添加失败')</script>");
}
}
/// <summary>
/// 登录
/// </summary>
/// <returns></returns>
public ActionResult login()
{
return View();
}
/// <summary>
/// 登录
/// </summary>
/// <param name="model"></param>
/// <returns></returns>
[HttpPost]
public ActionResult login(loginM model)
{
Login m = new Login();
m.name = model.name;
m.pwd = model.pwd;
Session["name"] = m.name;
Uri uri = new Uri("http://localhost:1036/");
HttpClient client = new HttpClient();
client.BaseAddress = uri;
client.DefaultRequestHeaders.Accept.Add(new System.Net.Http.Headers.MediaTypeWithQualityHeaderValue("application/json"));
HttpContent cont = new StringContent(JsonConvert.SerializeObject(m));
cont.Headers.ContentType = new System.Net.Http.Headers.MediaTypeHeaderValue("application/json");
var pp = "";
HttpResponseMessage mesa = client.PostAsync("actionApi/showApi/login", cont).Result;
if (mesa.IsSuccessStatusCode)
{
pp = mesa.Content.ReadAsStringAsync().Result;
}
if (Convert.ToInt32(pp) > 0)
{
return Content("<script>alert('登录成功');location.href = '/show/Index';</script>");
}
else
{
return Content("<script>alert('登录失败')</script>");
}
}
/// <summary>
/// 删除
/// </summary>
/// <param name="id"></param>
/// <returns></returns>
public ActionResult shan(int id)
{
Uri uri = new Uri("http://localhost:1036/");
HttpClient client = new HttpClient();
client.BaseAddress = uri;
client.DefaultRequestHeaders.Accept.Add(new System.Net.Http.Headers.MediaTypeWithQualityHeaderValue("application/json"));
var pp = "";
HttpResponseMessage mesa = client.DeleteAsync("actionApi/showApi/shan/" + id).Result;
if (mesa.IsSuccessStatusCode)
{
pp = mesa.Content.ReadAsStringAsync().Result;
}
if (Convert.ToInt32(pp) > 0)
{
return Content("<script>alert('删除成功');location.href = '/show/Index';</script>");
}
else
{
return Content("<script>alert('删除失败')</script>");
}
}
/// <summary>
/// 修改
/// </summary>
/// <param name="id"></param>
/// <returns></returns>
public ActionResult xiu(int id)
{
Uri uri = new Uri("http://localhost:1036/");
HttpClient client = new HttpClient();
client.BaseAddress = uri;
client.DefaultRequestHeaders.Accept.Add(new System.Net.Http.Headers.MediaTypeWithQualityHeaderValue("application/json"));
HttpResponseMessage message = client.GetAsync("actionApi/showApi/dan?id=" + id).Result;
List<Allcs> tt = new List<Allcs>();
if (message.IsSuccessStatusCode)
{
string pp = message.Content.ReadAsStringAsync().Result;
tt = JsonConvert.DeserializeObject<List<Allcs>>(pp);
}
client.Dispose();//释放
//下拉
Uri uris = new Uri("http://localhost:1036/");
HttpClient clients = new HttpClient();
clients.BaseAddress = uris;
clients.DefaultRequestHeaders.Accept.Add(new System.Net.Http.Headers.MediaTypeWithQualityHeaderValue("application/json"));
HttpResponseMessage mess = clients.GetAsync("actionApi/showApi/xia").Result;
List<stutype> tts = new List<stutype>();
if (mess.IsSuccessStatusCode)
{
string pp = mess.Content.ReadAsStringAsync().Result;
tts = JsonConvert.DeserializeObject<List<stutype>>(pp);
SelectList list = new SelectList(tts, "Sids", "Sname");
ViewBag.xia = list;
}
clients.Dispose();//释放
return View(tt[0]);//
}
/// <summary>
/// 修改
/// </summary>
/// <param name="mdoel"></param>
/// <returns></returns>
[HttpPost]
public ActionResult xiu(stuM mdoel)
{
//修改图片 img是一个新建的文件夹
var file = Request.Files["tu"];
var names = "/img/" + file.FileName;
file.SaveAs(Server.MapPath(names));
//修改传值
Allcs m = new Allcs();
m.men = mdoel.men;
m.name = mdoel.name;
m.number = mdoel.number;
m.shijian =mdoel.shijian;
m.Sids = mdoel.Sids;
m.id = mdoel.id;
//地址
Uri uri = new Uri("http://localhost:1036/");
HttpClient client = new HttpClient();
client.BaseAddress = uri;
client.DefaultRequestHeaders.Accept.Add(new System.Net.Http.Headers.MediaTypeWithQualityHeaderValue("application/json"));
HttpContent cont = new StringContent(JsonConvert.SerializeObject(m));
cont.Headers.ContentType = new System.Net.Http.Headers.MediaTypeHeaderValue("application/json");
var pp = "";
HttpResponseMessage mesa = client.PutAsync("actionApi/showApi/xiu", cont).Result;
if (mesa.IsSuccessStatusCode)
{
pp = mesa.Content.ReadAsStringAsync().Result;
}
if (Convert.ToInt32(pp) > 0)
{
return Content("<script>alert('修改成功');location.href = '/show/Index';</script>");
}
else
{
return Content("<script>alert('修改失败')</script>");
}
}
}
}
显示页面的方法
@using Webdiyer.WebControls.Mvc; //分页
@model PagedList<WebApplication1.Allcs>
类型:
@Html.DropDownList("typeid",ViewBag.xia as SelectList,"选择")
收费人:<input id="Text1" type="text" />
<input id="Button1" type="button" value="查询" onclick="cha()" />
<input id="Button1" type="button" value="添加" onclick="yang()" />
<table>
<tr>
<td>编号</td>
<td>门牌号</td>
<td>类型</td>
<td>费用</td>
<td>收费人</td>
<td>时间</td>
<td>操作</td>
</tr>
<tbody>
@foreach (var item in Model)
{
<tr>
<td>@item.id</td>
<td>@item.men</td>
<td>@item.Sname</td>
<td>@item.number</td>
<td>@item.name</td>
<td>@item.shijian</td>
<td><a href="#" onclick="shan(@item.id)">删除</a>
<a href="/show/xiu/@item.id" >修改</a></td>
</tr>
}
</tbody>
</table>
@*分页*@
@Html.Pager(Model, new PagerOptions { PageIndexParameterName = "pageIndex" }) //分页
</div>
<script>
//添加
function yang()
{
location.href = '/show/add';
}
//查询
function cha() {
var name = $("#Text1").val();
var type = $("#typeid").val();
location.href = '/show/Index?name=' + name + "&type=" + type;
}
//删除
function shan(id)
{
location.href = '/show/shan?id='+id;
}
</script>
添加页面的方法
@model WebApplication1.Allcs
//"add", "show", FormMethod.Post, new { @enctype = "multipart/form-data" } 做添加图片时用
@using (Html.BeginForm("add", "show", FormMethod.Post, new { @enctype = "multipart/form-data" }))
{
<table>
<tr>
<td>门牌号</td>
<td>@Html.TextBoxFor(s=>s.men)</td>
</tr>
<tr>
<td>类别</td>
<td>@Html.DropDownListFor(s=>s.Sids,ViewBag.xia as SelectList)</td>
</tr>
<tr>
<td>费用</td>
<td>@Html.TextBoxFor(s => s.number)</td>
</tr>
<tr>
<td>收费人</td>
<td>@Html.TextBoxFor(s => s.name)</td>
</tr>
<tr>
<td>时间</td>
<td>@Html.TextBoxFor(s => s.shijian)</td>
</tr>
<tr>
<td>图片</td>
<td><input type="file" name="tu" /> </td>
</tr>
<tr>
<td></td>
<td><input id="Submit1" type="submit" value="添加" /></td>
</tr>
</table>
}
修改的方法
@model WebApplication1.Allcs
//"add", "show", FormMethod.Post, new { @enctype = "multipart/form-data" } 做修改图片时用
@using (Html.BeginForm())
{
<table>
<tr>
<td>门牌号</td>
<td>@Html.TextBoxFor(s => s.men)</td>
</tr>
<tr>
<td>类别</td>
<td>@Html.DropDownListFor(s => s.Sids, ViewBag.xia as SelectList)</td>
</tr>
<tr>
<td>费用</td>
<td>@Html.TextBoxFor(s => s.number)</td>
</tr>
<tr>
<td>收费人</td>
<td>@Html.TextBoxFor(s => s.name)</td>
</tr>
<tr>
<td>时间</td>
<td>@Html.TextBoxFor(s => s.shijian)</td>
</tr>
<tr>
<td>图片</td>
<td><img src="@Model.tu" alt="" style="width:50px;height:50px" /></td>
<td><input type="file" name="tu" /> </td>
</tr>
<tr>
<td><input id="Text1" type="hidden" value="@Model.id" /></td>
<td><input id="Submit1" type="submit" value="添加" /></td>
</tr>
</table>
}
配置
config.Routes.MapHttpRoute(
name: "actionApi",
routeTemplate: "actionApi/{controller}/{action}/{id}",
defaults: new { id = RouteParameter.Optional }
);
mvc控制器的更多相关文章
- ABP文档 - Mvc 控制器
文档目录 本节内容: 简介 AbpController基类 本地化 其它 过滤 异常处理和结果包装 审计日志 验证 授权 工作单元 反伪造 模型绑定器 简介 ABP通过nuget包Abp.Web.Mv ...
- ABP理论学习之MVC控制器(新增)
返回总目录 本篇目录 介绍 AbpController基类 本地化 异常处理 响应结果的包装 审计日志 授权 工作单元 其他 介绍 ABP通过Abp.Web.Mvc nuget包集成了ASP.NET ...
- ASP.NET MVC 控制器激活(一)
ASP.NET MVC 控制器激活(一) 前言 在路由的篇章中讲解了路由的作用,讲着讲着就到了控制器部分了,从本篇开始来讲解MVC中的控制器,控制器是怎么来的?MVC框架对它做了什么?以及前面有的篇幅 ...
- ASP.NET MVC 控制器激活(二)
ASP.NET MVC 控制器激活(二) 前言 在之前的篇幅中,用文字和图像来表示了控制器的激活过程,描述的角度都是从框架默认实现的角度去进行描述的,这样也使得大家都可以清楚的知道激活的过程以及其中涉 ...
- ASP.NET MVC 控制器激活(三)
ASP.NET MVC 控制器激活(三) 前言 在上个篇幅中说到从控制器工厂的GetControllerInstance()方法来执行控制器的注入,本篇要讲是在GetControllerInstanc ...
- 在MVC控制器里面使用dynamic和ExpandoObject,实现数据转义的输出
在很多时候,我们在数据库里面定义表字段和实际在页面中展示的内容,往往是不太匹配的,页面数据可能是多个表数据的综合体,因此除了我们在表设计的时候考虑周到外,还需要考虑数据展现的处理.如果是常规的处理,那 ...
- 学习ASP.NET MVC(二)——我的第一个ASP.NET MVC 控制器
MVC全称是Model View Controller,是模型(model)-视图(view)-控制器(controller)的缩写,是一种软件设计典范,用一种业务逻辑和数据显示分离的方法组织代码,将 ...
- MVC控制器获取@Html.DropDownList值
MVC控制器获取@Html.DropDownList值 发表于 2014 年 4 月 1 日 作者 efour — 暂无评论 先贴一段代码,演示@Html.DropDownList的使用. 前台 前台 ...
- .Net MVC 导入导出Excel总结(三种导出Excel方法,一种导入Excel方法) 通过MVC控制器导出导入Excel文件(可用于java SSH架构)
.Net MVC 导入导出Excel总结(三种导出Excel方法,一种导入Excel方法) [原文地址] 通过MVC控制器导出导入Excel文件(可用于java SSH架构) public cl ...
- 基于MVC4+EasyUI的Web开发框架形成之旅--MVC控制器的设计
自从上篇<基于MVC4+EasyUI的Web开发框架形成之旅--总体介绍>总体性的概括,得到很多同行的关注和支持,不过上一篇主要是介绍一个总体的界面效果和思路,本系列的文章将逐步介绍其中的 ...
随机推荐
- WebSocket 的理解
WebSocket是HTML5开始提供的一种浏览器与服务器间进行全双工通讯的网络技术.依靠这种技术可以实现客户端和服务器端的长连接,双向实时通信. 它的最大特点就是,服务器可以主动向客户端推送信息,客 ...
- Windows 7远程桌面设置
1. 开启防火墙 可在”计算机管理“中,打开"服务和应用程序"-"服务",找到"Windows Firewall",双击"Wind ...
- mac电脑php+mysql+nginx+phpmyadmin环境搭建
英文原文:http://blog.frd.mn/install-nginx-php-fpm-mysql-and-phpmyadmin-on-os-x-mavericks-using-homebrew/ ...
- oracle sql生成临时递增数据
1.生成1至10记录 select rownum from dual connect 结果: 12345678910 2.生成最近12个月记录 ), 'yyyyMM') time from dual ...
- P4705 玩游戏
思路 超级麻烦... 写了一堆最后常数太大T飞了... 真的难受 发现solve函数可以不用把下一层复制上来,直接传指针就可以,下次再说写不写叭 思路 \[ ans_k=\sum_{i=1}^n\su ...
- SharePoint2007使用WebPart加载UserControl
之前一直做SharePoint2010开发,最近转向了2007开发,感觉两者开发时有很多地方不一样,我现在接触到2007开发项目里面使用Module去加载Application Page,而在Appl ...
- vim 翻页命令
整页翻页 ctrl-f:向下翻一页 f含义:forword ctrl-b:向上翻一页 b含义:backward 翻半页 ctrl-d:向下翻半页 d含义:down ctlr-u:向上翻半 ...
- eclipse报错:Multiple annotations found at this line: - String cannot be resolved to a type解决方法实测
Multiple annotations found at this line:- String cannot be resolved to a type- The method getContext ...
- Mysql_大字段问题Row size too large.....not counting BLOBs, is 8126.
[问题描述] 1.从myslq(5.7.19-0ubuntu0.16.04.1)中导出sql脚本,导入到mysql(5.5.27)中,报如下错误:Row size too large. The max ...
- lua 5.3.5 安装/初体验
安装 官网http://www.lua.org/start.html 参考 https://blog.csdn.net/qq_23954569/article/details/70879672 cd ...