控制器

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控制器的更多相关文章

  1. ABP文档 - Mvc 控制器

    文档目录 本节内容: 简介 AbpController基类 本地化 其它 过滤 异常处理和结果包装 审计日志 验证 授权 工作单元 反伪造 模型绑定器 简介 ABP通过nuget包Abp.Web.Mv ...

  2. ABP理论学习之MVC控制器(新增)

    返回总目录 本篇目录 介绍 AbpController基类 本地化 异常处理 响应结果的包装 审计日志 授权 工作单元 其他 介绍 ABP通过Abp.Web.Mvc nuget包集成了ASP.NET ...

  3. ASP.NET MVC 控制器激活(一)

    ASP.NET MVC 控制器激活(一) 前言 在路由的篇章中讲解了路由的作用,讲着讲着就到了控制器部分了,从本篇开始来讲解MVC中的控制器,控制器是怎么来的?MVC框架对它做了什么?以及前面有的篇幅 ...

  4. ASP.NET MVC 控制器激活(二)

    ASP.NET MVC 控制器激活(二) 前言 在之前的篇幅中,用文字和图像来表示了控制器的激活过程,描述的角度都是从框架默认实现的角度去进行描述的,这样也使得大家都可以清楚的知道激活的过程以及其中涉 ...

  5. ASP.NET MVC 控制器激活(三)

    ASP.NET MVC 控制器激活(三) 前言 在上个篇幅中说到从控制器工厂的GetControllerInstance()方法来执行控制器的注入,本篇要讲是在GetControllerInstanc ...

  6. 在MVC控制器里面使用dynamic和ExpandoObject,实现数据转义的输出

    在很多时候,我们在数据库里面定义表字段和实际在页面中展示的内容,往往是不太匹配的,页面数据可能是多个表数据的综合体,因此除了我们在表设计的时候考虑周到外,还需要考虑数据展现的处理.如果是常规的处理,那 ...

  7. 学习ASP.NET MVC(二)——我的第一个ASP.NET MVC 控制器

    MVC全称是Model View Controller,是模型(model)-视图(view)-控制器(controller)的缩写,是一种软件设计典范,用一种业务逻辑和数据显示分离的方法组织代码,将 ...

  8. MVC控制器获取@Html.DropDownList值

    MVC控制器获取@Html.DropDownList值 发表于 2014 年 4 月 1 日 作者 efour — 暂无评论 先贴一段代码,演示@Html.DropDownList的使用. 前台 前台 ...

  9. .Net MVC 导入导出Excel总结(三种导出Excel方法,一种导入Excel方法) 通过MVC控制器导出导入Excel文件(可用于java SSH架构)

    .Net MVC  导入导出Excel总结(三种导出Excel方法,一种导入Excel方法) [原文地址] 通过MVC控制器导出导入Excel文件(可用于java SSH架构)   public cl ...

  10. 基于MVC4+EasyUI的Web开发框架形成之旅--MVC控制器的设计

    自从上篇<基于MVC4+EasyUI的Web开发框架形成之旅--总体介绍>总体性的概括,得到很多同行的关注和支持,不过上一篇主要是介绍一个总体的界面效果和思路,本系列的文章将逐步介绍其中的 ...

随机推荐

  1. websocket flutter

    https://stackoverflow.com/questions/51077233/how-can-i-use-socket-in-flutter-app import 'dart:io'; i ...

  2. 图像旋转、伸缩的自写matlab实现

    一.图像的旋转 今天的代码不是自己写的,缺少一些时间.但是认认真真推导了一下旋转的公式,代码的思想与原博博主一致,致敬! 愚以为,自己来实现图像旋转算法的关键点有二:其一,确定旋转后的图像边界.其二, ...

  3. Java链接MySQL数据库的用配置文件和不用配置文件的代码

    1.利用配置文件(db.properties)链接MySQL数据库 package tool; import java.io.FileInputStream;import java.sql.Conne ...

  4. 史上最全!Selenium元素定位的30种方式

    Selenium对网页的控制是基于各种前端元素的,在使用过程中,对于元素的定位是基础,只有准去抓取到对应元素才能进行后续的自动化控制,我在这里将对各种元素定位方式进行总结归纳一下. 这里将统一使用百度 ...

  5. MySQL之 视图,触发器,存储过程,函数,事物,数据库锁,数据库备份

    1.视图 视图: 是一个虚拟表,其内容由查询定义: 视图有如下特点;  1. 视图的列可以来自不同的表,是表的抽象和逻辑意义上建立的新关系.  2. 视图是由基本表(实表)产生的表(虚表).  3. ...

  6. 解决win10 蓝牙设备只能配对无法连接 ,并且删除设备无效的问题

    系统环境: win10家庭版 dell本 问题描述:蓝牙设备(比如蓝牙键盘,蓝牙音箱)出现无法连接的情况,打算删除已配对的设备,再重新配对连接.但删除设备后重启蓝牙,那些原本被删除的设备又自动配对上, ...

  7. 剑指offer:顺时针打印矩阵

    问题描述 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下4 X 4矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 则依次打印出数 ...

  8. 使用VSCode调试Jest

    0. 环境 Node版本:8.12.0 操作系统:windows10 1. 配置launch.json { "version": "0.2.0", " ...

  9. 从svn到git开发转变

    前言:目前的公司的开发技术还是处于刀耕火种的年代,react,vue已经火到不行了,可是还在用jQuery一遍遍处理着dom.版本控制用的是svn,这里也不是说svn不好,在windows下svn的“ ...

  10. php 更改PHP临时文件的目录

    $_FILES['upfile']['tmp_name']  获取php.ini 存放路径 php.ini 里 upload_tmp_dir 设置一个全新的目录