使用Entity Framework  创建数据库与表

前面文章有说到使用SQL语句动态创建数据库与数据表,这次直接使用Entriy Framwork 的ORM对象关系映射来创建数据库与表

一 新建项目OrmDemo

二  添加 EntityFramework.dll 与System.Data.Entity.dll 引用,EntityFramework可直接在NuGet下载

三、创建实体类

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
public class Student
    {
        public Student()
        {
 
        }
        public int StudentID { getset; }
        public string StudentName { getset; }
 
    }
 
 
    public class Standard
    {
        public Standard()
        {
 
        }
        public int StandardId { getset; }
        public string StandardName { getset; }
 
    }

四、 添加SchoolContext 继承DbContext

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
public class SchoolContext : DbContext
    {
        public SchoolContext()
            base("name=testdb")
        {
 
        }
 
        public DbSet<Student> Students { getset; }
        public DbSet<Standard> Standards { getset; }
 
        protected override void OnModelCreating(DbModelBuilder modelBuilder)
        {
            base.OnModelCreating(modelBuilder);
        }
    }

此处注意 name = testdb 要与配置文件中的名称一致,如下图。TEST_DB1 为数据库名,

五、最后调用

1
2
3
4
5
6
7
using (var ctx = new SchoolContext())
            {
                Student stud = new Student() { StudentName = "New Student" };
 
                ctx.Students.Add(stud);
                ctx.SaveChanges();
            }

  

参考 https://www.cnblogs.com/CreateMyself/p/4739922.html

1.添加QRCoder包引用

2. public IActionResult MakeQrCode()
        {

  string url="https://www.baidu.com";

  var generator = new QRCodeGenerator();

  var codeData = generator.CreateQrCode(str,QRCodeGenerator.ECCLevel.M,true);

  var qrcode = new QRCode(codeData);
  var qrImage = qrcode.GetGraphic(100,Color.Black,Color.White,true);
  var ms = new MemoryStream();

  //图片格式指定为png
        qrImage.Save(ms,ImageFormat.Jpeg);

   byte[] bytes = ms.GetBuffer();
        ms.Close();
        return File(bytes, "image/Png");

}

后台Post/Get 请求接口 方式

 

Post请求

 1  public string HttpPost(string Url, string postDataStr)
 2     {
 3         try
 4         {
 5             HttpWebRequest request = (HttpWebRequest)WebRequest.Create(Url);
 6             request.Method = "POST";
 7             request.ContentType = "application/x-www-form-urlencoded";//请求方约定好
 8
 9             byte[] bs = Encoding.UTF8.GetBytes(postDataStr);
10             request.ContentLength = bs.Length;
11             using (Stream reqStream = request.GetRequestStream())
12             {
13                 reqStream.Write(bs, 0, bs.Length);
14             }
15
16             HttpWebResponse response;
17             response = (HttpWebResponse)request.GetResponse();
18
19             Stream myResponseStream = response.GetResponseStream();
20             StreamReader myStreamReader = new StreamReader(myResponseStream, Encoding.GetEncoding("utf-8"));//一般参数带中文 用utf-8
21             string retString = myStreamReader.ReadToEnd();
22             myStreamReader.Close();
23             myResponseStream.Close();
24
25             return retString;
26         }
27         catch (Exception ex)
28         {
29             LogHelper.WriteLog(ex.Message, "");
30         }
31         return null;
32     }

Get 请求

 1   public static string Get_Http(string strUrl, int timeout)
 2     {
 3         string strResult;
 4         try
 5         {
 6             HttpWebRequest myReq = (HttpWebRequest)HttpWebRequest.Create(strUrl);
 7             myReq.Timeout = timeout;
 8             HttpWebResponse HttpWResp = (HttpWebResponse)myReq.GetResponse();
 9             Stream myStream = HttpWResp.GetResponseStream();
10             StreamReader sr = new StreamReader(myStream, Encoding.UTF8);
11             StringBuilder strBuilder = new StringBuilder();
12             while (-1 != sr.Peek())
13             {
14                 strBuilder.Append(sr.ReadLine());
15             }
16
17             strResult = strBuilder.ToString();
18         }
19         catch (Exception exp)
20         {
21             strResult = "错误:" + exp.Message;
22         }
23
24         return strResult;
25     }

WebForm 页面ajax 请求后台页面 方法

 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
function ReturnOperation(InventoryID) {
             //入库 接口
             if (confirm('你确认?')) {
                 $.ajax({
                     type: "post",
                     url: "xxx.aspx/InStorage",
                     data: "{InventoryID:'"+InventoryID+"'}",//注意,json 对象外面 加 双引号 
                     contentType: "application/json",
                     dataType: "json",
                     success: function (r) {
                         if (r.d =="1") {
              alert("入库成功");
                         else {
                             alert("入库失败");
                         }
                     },
                     error: function (e) {
                         alert("错误是:" + e.responseText);
                     }
                 })
             else {
 
             }
         }               

  这是前端code

    [WebMethod]  //注意添加引用,方法为静态
    public static string InStorage(string InventoryID)
    {

       return InventoryID;
    }

这是xxx.aspx 页面内的方法

实现输入框小数多 自动进位展示,编辑时实际值不变

 

今天遇到个业务需求,要求输入框,输入数字的小数位数可以很多位,但移开后显示,只显示小数点后两位 (四舍五入),当要编辑的时候,展现其原来的输入数据。

闲话不多说,当时也考虑用第三方插件,但感觉对现有框架后台数据取值有影响;

感觉还是前端处理下,直接采用两个input 一个用来显示四舍五入,一个用来存真实的值,

然后就是焦点移进移出的事件了,移进去控制真实input显示,移出来触发四舍五入的显示,当然这两个input得保持在同一位置上,定位好了就行。

思路出来了,就开始撸代码了!

 1 <body>
 2     <table>
 3         <tr>
 4             <td style="position: relative;">
 5                 <input type="text" style="position: absolute;" class="TrueShow" onblur="ConvertToShow(this);" />
 6
 7                 <input type="text" style="display:none;" class="FalseShow" value="" onfocus="ShowToConvert(this);" />
 8             </td>
 9         </tr>
10         <tr>
11             <td style="position: relative;">
12                 <input type="text" style=" position: absolute;" class="TrueShow" onblur="ConvertToShow(this);" />
13
14                 <input type="text" style="display:none;" class="FalseShow" value="" onfocus="ShowToConvert(this);" />
15             </td>
16         </tr>
17     </table>
18     <script src="jquery-1.12.4.js"></script>
19     <script type="text/javascript">
20         function ConvertToShow(obj) {
21             obj.setAttribute("style", "display:none");
22             var FalseShow = $(obj).parent().find(".FalseShow");
23             FalseShow.css("display", "block");
24             if (obj.value == "" || obj.value == null) {
25                 FalseShow.val(obj.value);
26             } else {
27                 var showVal = parseFloat(obj.value || 0);
28                 showVal = showVal.toFixed(2);
29                 FalseShow.val(showVal);
30             }
31
32         }
33         function ShowToConvert(obj) {
34             obj.setAttribute("style", "display:none;width:95%");
35             var TrueShow = $(obj).parent().find(".TrueShow");
36             TrueShow.css('display', 'block');
37             TrueShow.css('width', '95%');
38             TrueShow.focus();
39             }
40     </script>
41         </body>

快速掌握Gif动态图实现代码

 

版权声明:本文为博主原创文章,未经博主允许不得转载。

前言:Gif一种动态图片,网上有很多制作这个的工具,包括PS都有,但作为一名程序员,我觉得如果自己通过编写代码把它实现,不但是对代码的掌握与复习,而且也是熟悉其原理的一个过程。额外说一句,个人不建议copy代码的,所以采用截图的方式展现给大家,同时希望大家自己去实践下才是真理!

下面开始我们的GIF制作之旅吧

首先,我们的添加一个引用Gif.Components.dll

其次,我们建一个web工程,里面创建两个html页面,一个一般处理程序,两个文件夹(用于服务器存储上传图片和生成gif图片所在的文件夹)

前端采用<input type=”file” multiple="multiple" />标签实现选择多文件上传,具体代码如下:

注意:我这里默认提交上来的文件都为图片格式,所以没去添加限制和判断;

下图是Gif生成的方法,以及需要的一些参数

下图,就是调用GIF方法,以及获取前端传来的文件,并进行服务器存储和gif生成的核心步骤

需注意的是,路径是相对路径;

后言:(经人提醒截图看不清,本人立即修改,欢迎大家提出不足,谢谢)本文章有不足之处请多多包涵,其目的就是让你了解下GIF的生成也是很简单的

C#处理和对接HTTP接口请求

 

  对于现在接口泛滥的时代,了解和处理接口对于一名程序员来说是很有必要的!

  在对接时对于对方发过来的文档,需要认真看一遍,有疑问的比如加密等,需特别提出来和对方交接;

  第一步,在对接接口时,你应该拿到服务端那边的key和partner,相当于用户和密码的意思;在配置文件里面配置好,如下图:

  第二步,加密生成sign,一般是把加密特别抽出来作为一个方法,注意的是,需按照服务端指定的加密方式进行加密,至于是MD5还是其他加密,按规则来;例如:

  第三步,拼接url,带上请求参数中间用&间隔,这个太简单了,就不举例了;

  第四步,按照拼接出来的url发送HTTP请求并返回响应过来的字符串;

  最后一步,对响应过来的xml或者其它格式的数据进行有需处理;

  

C# 动态创建SQL数据库(二) 在.net core web项目中生成二维码 后台Post/Get 请求接口 方式 WebForm 页面ajax 请求后台页面 方法 实现输入框小数多 自动进位展示,编辑时实际值不变 快速掌握Gif动态图实现代码 C#处理和对接HTTP接口请求的更多相关文章

  1. 在.net core web项目中生成二维码

    1.添加QRCoder包引用 2. public IActionResult MakeQrCode()        { string url="https://www.baidu.com& ...

  2. C# 动态创建SQL数据库(二)

    使用Entity Framework  创建数据库与表 前面文章有说到使用SQL语句动态创建数据库与数据表,这次直接使用Entriy Framwork 的ORM对象关系映射来创建数据库与表 一 新建项 ...

  3. C# 动态创建SQL数据库(一)

    最近在做项目中要求能够要求动态添加数据库并建表.具体思路如下 1 提供数据名,根据数据库创建数据库 2 自定数据库与数据表,提供数据表自定与数据类型创建表 创建sqlhelper类,用于数据库操作 u ...

  4. 在.net core web 项目中操作MySql数据库(非ORM框架,原生sql语句方式)

    本案例通过MySql.Data和Dapper包执行原生sql,实现对数据库的操作. 操作步骤: 第1步:在MySql数据库中新建表User(使用Navicat For MySql工具) 建表语句: c ...

  5. Java Web项目中连接Access数据库的配置方法

    本文是对前几天的"JDBC连接Access数据库的几种方式"这篇的升级.因为在做一些小项目的时候遇到的问题,因此才决定写这篇博客的.昨天已经将博客公布了.可是后来经过一些验证有点问 ...

  6. 真分布式SolrCloud+Zookeeper+tomcat搭建、索引Mysql数据库、IK中文分词器配置以及web项目中solr的应用(1)

    版权声明:本文为博主原创文章,转载请注明本文地址.http://www.cnblogs.com/o0Iris0o/p/5813856.html 内容介绍: 真分布式SolrCloud+Zookeepe ...

  7. Java之——Web项目中DLL文件动态加载方法

    本文转自:https://blog.csdn.net/l1028386804/article/details/53903557 在Java Web项目中,我们经常会用到通过JNI调用dll动态库文件来 ...

  8. Web项目中创建简单的错误处理页面

    当应用程序出现错误的时候,如果没有做错误页面处理的话,会直接输出一些敏感的信息出来,有时候甚至会直接将项目所在的物理路径给显示出来,严重缺乏安全性,并且错误种类繁多,页面风格不一,导致用户体验不好,本 ...

  9. 在java中生成二维码,并直接输出到jsp页面

    在java中生成的二维码不存到磁盘里要直接输出到页面上,这就需要把生成的二维码直接以流的形式输出到页面上,我用的是myeclipse 和 tomcat 它的原理是:在加载页面时,根据img的src(c ...

随机推荐

  1. MAC实用的小工具

    一.XtraFinder(右键菜单扩展) http://www.xuebuyuan.com/173454.html http://www.mamicode.com/info-detail-111618 ...

  2. 【SQL篇章--DATABASE/EVENTS】

    [SQL篇章][SQL语句梳理 :--基于MySQL5.6][已梳理:DATABASE/EVENTS][会坚持完善]   目录: 1. Data Definition Statements: 1.1 ...

  3. iOS5.0以上使用新浪微博开放平台OAuth 续(及解决登录无效问题)

    新浪微博开放平台为第三方应用提供了简便的合作模式,满足了手机用户和平板电脑用户随时随地分享信息的需求.通过调用平台的api即可实现很多微博上的功能. 本篇主要目的是记录新浪微博移动SDK iOS版本的 ...

  4. Combination Sum | &amp; || &amp; ||| &amp; IV

    Combination Sum | Given a set of candidate numbers (C) and a target number (T), find all unique comb ...

  5. 在Windows上安装Maven

      下载 Maven 最新版本. http://maven.apache.org/download.cgi   1,下载包后,解压到相应特定位置. 2,将 [解压位置]/bin  加入到Path 3, ...

  6. YOU邮件

    include("class.phpmailer.php");include("class.smtp.php");//获取一个外部文件的内容$mail      ...

  7. 从程序员的角度设计一个Java的神经网络

    欢迎大家前往云+社区,获取更多腾讯海量技术实践干货哦~ 来自维基百科: 人工神经网络(ANN)或连接系统是受生物神经网络启发构成生物大脑的计算系统.这样的系统通过考虑例子来学习(逐步提高性能)来完成任 ...

  8. 测试SM图床

  9. centos 安装 pcre

    版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/luozhonghua2014/article/details/37054235 #rpm -qa | ...

  10. programmatically detect whenever test run is in debug mode

    if (System.Diagnostics.Debugger.IsAttached)    // code or timeout value when running tests in debug ...