那天有个小孩教我WCF[一][2/3]

接着上次的继续讲吧

我们开始吧

 

9.创建数据库

 

use master
go
--创建库
if exists(select * from sysdatabases where name='NewsDB')
drop database NewsDB
create database NewsDB
on primary
(
name='NewsDB_data',
filename='D:\NewsDB_data.mdf',
filegrowth=30%,
size=5
)log on
(
name='NewsDB_log',
filename='D:\NewsDB_log.ldf',
size=2,
filegrowth=10%
)
go
 
--创建表News
use NewsDB
go
if exists(select * from sysobjects where name='News')
drop table News
create table News(
  NewsID int identity(1,1) primary key,
  NewsTitle nvarchar(50) not null,
  Content nvarchar(max) not null,
  NewsType int not null,
  publishTime datetime not null,
  LastUpdateTime datetime not null,
  Author nvarchar(20) not null,
  LastAuthor nvarchar(20) not null,
  ReadCount int not null
)

 

 

10. 添加Linq to SQL文件

 

 

11. 实现服务

11.1 修改NewsTypeEnum枚举文件

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Runtime.Serialization;
 
namespace NewsInterface
{
    [DataContract]
    public enum NewsTypeEnum
    {
        [EnumMember]
        Sports=1,
        [EnumMember]
        IT=2,
        [EnumMember]
        Country=3,
        [EnumMember]
        Funny=4
    }
}

 

11.2 在D盘放一张 1.jpg图片作为测试用

11.jpg

 

11.3 打开NewsImpl.cs文件,实现服务

修改NewsDto,添加NewsID属性

image

NewsImpl.cs代码实现大致如下

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Runtime.Serialization;
using System.ServiceModel;
using NewsInterface;
using System.IO;
 
namespace NewsServices
{
    public class NewsImpl:INewsInterface
    {
 
        public int NewsAdd(NewsDto dto)
        {
            Console.WriteLine("添加中...");
            using (NewsDataContext db=new NewsDataContext())
            {
                News news = new News();
                news.Author=dto.Author;
                news.Content=dto.Content;
                news.LastAuthor=dto.LastAuthor;
                news.LastUpdateTime=dto.LastUpdateTime;
                news.NewsType=dto.NewsType.GetHashCode();
                news.publishTime = dto.publishTime;
                news.ReadCount = dto.ReadCount;
                news.NewsTitle = dto.NewsTitle;
                db.News.InsertOnSubmit(news);
                db.SubmitChanges();
                Console.WriteLine("添加成功!");
                return news.NewsID;
            }
        }
 
        public bool NewsDelete(NewsDto dto)
        {
            Console.WriteLine("删除中...");
            using (NewsDataContext db = new NewsDataContext())
            {
                try
                {
                    News model = db.News.FirstOrDefault(x => x.NewsID == dto.NewsID);
                    db.News.DeleteOnSubmit(model);
                    db.SubmitChanges();
                    Console.WriteLine("删除成功");
                    return true;
                }
                catch
                {
                    return false;
                }
            }
        }
 
        public bool NewsUpdate(NewsDto dto)
        {
            throw new NotImplementedException();
        }
 
        public List<NewsDto> NewsList()
        {
            Console.WriteLine("请求获得新闻列表");
            using (NewsDataContext db = new NewsDataContext())
            {
                var d=from o in db.News
                        select new NewsDto
                        {
                            Author=o.Author,
                            LastAuthor=o.LastAuthor,
                            LastUpdateTime=o.LastUpdateTime,
                            NewsID=o.NewsID,
                            Content=o.Content,
                            NewsTitle=o.NewsTitle,
                            publishTime=o.publishTime,
                            ReadCount=o.ReadCount
                        };
                return d.ToList<NewsDto>();
            }
        }
 
        public byte[] GetNewsImage(string Id)
        {
            Console.WriteLine("开始获得图片:"+Id+"...");
            byte[] buff;
            string path = @"D:\1.jpg";
            FileStream fileStream = new FileStream(path, FileMode.Open, FileAccess.Read);
            BinaryReader br = new BinaryReader(fileStream);
            buff = br.ReadBytes((int)fileStream.Length);
            Console.WriteLine("获取成功!");
            return buff;
        }
    }
}

 

这里修改我没有去实现,感兴趣自己可以实现

LINQ to SQL如果不会的,可以 点击学习  那天有个小孩跟我说LINQ

 

 

11.4 重新生成解决方案,编译程序

 

 

12.  公开元数据

    现在可以通过添加配置来托管服务了,并公开元数据。公开元数据之后,Visual Studio就可以下载WSDL文件,创建所需要的代理了。我们后期会教大家创建代理的其他方式

    现在用WCF配置编辑器打开NewsHosts应用程序的配置文件App.config

   image

新建服务行为的名称      ExposeMetaDataBehavior

元数据发布地址   http://localhost:1234/NewsService/Mex

下面具体配置一下

22

配置完成后App.config

image

配置成功后,将HOST设为启动项目,运行项目,打开浏览器输入

http://localhost:1234/NewsService/Mex

image

效果如果是这样子的,说明 成功的

 

 

13. 创建 NewsApplication客户端,我们使用Winform

窗体,我改成这样子了,上面的蓝色文字用于说明

image

 

最重要的一步,添加服务

先不用VS运行宿主

我们手动打开Debug文件夹下的 NewsHosts.exe

image

 

接下来看我演示一下

我们最后注释掉 identity节点,是为了方便测试

 

 

14 实现Winform后面的方法

  14.1 添加

     private void button1_Click(object sender, EventArgs e)
        {
            try
            {
                NewsService.NewsInterfaceClient client = new NewsService.NewsInterfaceClient();
                NewsService.NewsDto dto = new NewsService.NewsDto();
                dto.Author = "杨洋";
                dto.LastAuthor = "AaronYang";
                dto.publishTime = DateTime.Now;
                dto.LastUpdateTime = DateTime.Now;
                dto.NewsTitle = "测试标题:" + new Random().Next(10000).ToString();
                dto.Content = "测试内容" + new Random().Next(10000).ToString();
                dto.NewsType = NewsService.NewsTypeEnum.Country;
                dto.ReadCount = 0;
                MessageBox.Show("添加成功!成功后的ID为"+client.NewsAdd(dto).ToString());
            }
            catch (Exception ex)
            {
                richTextBox1.Text += Environment.NewLine + ex.Message;
            }
        }

14.2 获得新闻列表

      private void button2_Click(object sender, EventArgs e)
        {
            try
            {
                NewsService.NewsInterfaceClient client = new NewsService.NewsInterfaceClient();
                List<NewsService.NewsDto> list = client.NewsList();
                foreach (NewsService.NewsDto item in list)
                {
                    listBox1.Items.Add("标题:"+item.NewsTitle+"\t发布时间:"+item.publishTime.ToShortDateString());
                 }
            }
            catch (Exception ex)
            {
                richTextBox1.Text += Environment.NewLine + ex.Message;
            }
            
 
        }

 

 

14.3 获得图片并显示

    private void button3_Click(object sender, EventArgs e)
        {
            try
            {
                NewsService.NewsInterfaceClient client = new NewsService.NewsInterfaceClient();
                byte[] buff=client.GetNewsImage("1");
                TypeConverter converter = TypeDescriptor.GetConverter(typeof(Bitmap));
                Bitmap bitmap = (Bitmap)converter.ConvertFrom(buff);
                pictureBox1.Image = bitmap;
            }
            catch (Exception ex)
            {
                richTextBox1.Text += Environment.NewLine + ex.Message;
            }
        }

 

 

14.4 有的图片可能过大,可能响应的时候图片太大就不能显示了,我们需要修改宿主的WCF的配置

image

我们配置一下终结点(Endpoint)的绑定配置,名称就是 上面的<binding name=”这里的名字”>

 

我们还需要修改客户端的配置,使它可以接受超大的消息

打开NewsApplication的app.config文件

image

 

 

15.设置两个启动项目,运行查看效果

先生成解决方案,然后我们设置一下

111

效果图:

效果图

 

 

关于 获得列表,还有点问题

下次调,我再解决一下

 

 

关于NewsDto中我最后不是添加了一个NewsID吗,我没有添加DataMember属性,但是添加上去,似乎还是没有用,有人知道怎么解决吗

我把代码上传一下了,希望有人能棒棒我,感谢万分。        代码下载

 

这个是错误信息

接收对 http://localhost:1234/NewsMgr 的 HTTP 响应时发生错误。这可能是由于服务终结点绑定未使用 HTTP 协议造成的。这还可能是由于服务器中止了 HTTP 请求上下文(可能由于服务关闭)所致。有关详细信息,请参见服务器日志。

 

时间不早了,我先睡觉了,大家晚安

posted @ 2013-06-29 01:29  AYUI框架  阅读(2128)  评论(14编辑  收藏  举报