首先,为了安全起见,服务器的SQLSERVER不开放远程访问,这样,我们有两种方案可以选择,其一就是webservice,其二就是比较简单的XML,今天我主要讲XML。
先说明一下,两个网站域名为a.com和b.com,a.com是b.com的分站,它们的新闻是共享的,就是一样的,所以没必要在a.com数据库里再重复插入一批数据了。
解决方案:在b.com里建立一个开放的XML文件,供a.com访问,这样做是安全的,可行的。
首先在b.com里建立这样一个生成XML的文件:
public partial class _Default : System.Web.UI.Page
{
int rCount = 10;
int channelId = 1;
int classId = 1;
protected void Page_Load(object sender, EventArgs e)
{
this.rCount = Request.QueryString.AllKeys.Contains("r") ?
int.Parse(Request.QueryString["r"].Trim()) : this.rCount;
this.channelId = Request.QueryString.AllKeys.Contains("ch") ?
int.Parse(Request.QueryString["ch"]) : this.channelId;
this.classId = Request.QueryString.AllKeys.Contains("cl") ?
int.Parse(Request.QueryString["cl"]) : this.classId;
CreateXML();
}
/// <summary>
/// 从数据库中提取数据,生成XML文件
/// </summary>
/// <returns></returns>
public string CreateXML()
{
Response.Clear(); //删除所有缓存中的HTML输出
Response.ContentType = "text/xml";
// (ContentType 属性指定响应的 HTTP 内容类型) 页面类型为xml,默认为HTML,
常见的还有image/GIF 和image/JPEG
System.Data.DataSet data = B2ceduData.Data.B2cData.News(this.rCount,
this.channelId, this.classId);
if (data != null)
{
data.WriteXml(Response.OutputStream);
}
Response.Flush();//立即发送缓冲区中的输出(只有编译产生了至少256字节的数据,
才能在执行Response.Flush()以后将信息发到客户端并显示)
Response.End();
return data.GetXml();
}
}
}
下面程序接上面的,从b.com数据库里取出新闻列表
public static class B2cData
{
/// <summary>
/// 获取热门课程列表XML
/// </summary>
/// <param name="RowCount">数据行数</param>
/// <param name="ChannelID">频道ID</param>
/// <param name="ClassID">分类ID</param>
/// <returns></returns>
public static DataSet News(int RowCount, int ChannelID, int ClassID)
{
return News(RowCount, ChannelID, ClassID, DBConnectionHelper.ConnString);
}
/// <summary>
/// 获取热门课程列表XML
/// </summary>
/// <param name="RowCount">数据行数</param>
/// <param name="ChannelID">频道ID</param>
/// <param name="ClassID">分类ID</param>
/// <param name="ClassID">数据库连接字</param>
/// <returns></returns>
public static DataSet News(int RowCount, int ChannelID, int ClassID, string connStr)
{
try
{
System.Text.StringBuilder sql = new System.Text.StringBuilder();
sql.Append(@"SELECT ");
sql.Append(RowCount == 0 ? "" : string.Format("TOP {0} ", RowCount));
sql.Append(@"a.ArticleID,a.ChannelID,a.ClassID,a.Title,a.Subheading,
a.UpdateTime,a.CreateTime,a.LinkUrl,a.ChannelDir ");
sql.Append(@"FROM PE_Article a LEFT OUTER JOIN PE_Channel b ON
a.ChannelID=b.ChannelID ");
sql.Append(@"WHERE ");
sql.Append(string.Format(@" a.ChannelID={0} ", ChannelID));
sql.Append(string.Format(@"AND a.ClassID={0} ", ClassID));
sql.Append(@"ORDER BY A.UPDATETIME DESC");
DataSet ds = DBHelper.SELECT(sql.ToString(), connStr);
ds.DataSetName = DBConnectionHelper.InitialCatalog;
ds.Tables[0].TableName = "PE_Article";
return ds;
}
catch
{
return null;
}
}
}
OK,现在一个扩展名为aspx的xml文件已经建立好了,假设它的数径为www.b.com/news.aspx
好了,下面两个程序就是a.com下面的,它们将从b.com的news.aspx页面下得到最新的新闻列表
public partial class FromXmlGetDatum : System.Web.UI.Page
{
Web.Service.NewsService webRequest = null;
System.Text.StringBuilder html;
const int MAXROW = 10;
public FromXmlGetDatum()
{
this.webRequest = new Web.Service.NewsService();
}
protected void Page_Load(object sender, EventArgs e)
{
GetLatestNews("5.1", "1");
Response.Write(html);
}
// 获取最新资讯
void GetLatestNews(string id, string newsCategoryID)
{
html = new System.Text.StringBuilder();
html.Append("<div id=\"list_" + id.Replace(".", "") + "_1\" class=\"conn\"
style=\"display:block;\">");
html.Append("<table width=\"660\" border=\"0\" cellspacing=\"1\"
cellpadding=\"2\" bgcolor=\"#e9e9e9\" style=\"float:left;\">");
if (!string.IsNullOrEmpty(newsCategoryID))
{
List<Web.Service.XMLLastestNews> datas = this.webRequest.
RequestData(newsCategoryID, MAXROW).Cast<Web.Service.XMLLastestNews>().ToList();
if (datas.Count > 0)
{
foreach (var item in datas)
{
html.Append("<tr bgcolor=\"#FFFFFF\"><td><a href='" +
item.LinkUrl + "/" + Convert.ToDateTime(item.CreateTime).ToString("yyyyMM") + "/" +
item.ChannelDir + "_" + item.ArticleID + ".shtml' target='_blank'>" +
item.Title + "</a></td><td>"+item.CreateTime+"</td><td>"+item.Subheading+"</td></tr>");
}
}
else
{
html.Append("<tr bgcolor=\"#FFFFFF\"><td width=\"100%\"></td></tr>");
}
}
else
{
html.Append("<tr bgcolor=\"#FFFFFF\"><td width=\"100%\"></td><td></td><td></td></tr>");
}
html.Append("</table>");
html.Append("</div>");
}
}
namespace Web.Service
{
public class NewsService
{
const string REQUESTURL = "http://www.b.com/news.aspx?ch={0}&cl=1&r={1}"; //从这个XML文件里获取数据
#region IWebRequestService 成员
/// <summary>
/// 将XML对象转换为LIST实体返回
/// </summary>
/// <param name="id"></param>
/// <param name="num"></param>
/// <returns></returns>
public List<IWebRequestEntity> RequestData(string id, int num)
{
List<XMLLastestNews> data;
System.Xml.Linq.XElement xdoc = System.Xml.Linq.XElement.Load(
string.Format(REQUESTURL, id, num));
var items = xdoc.Descendants("PE_Article").Select(item =>
new Web.Service.XMLLastestNews
{
ArticleID = item.Element("ArticleID").Value,
ChannelID = item.Element("ChannelID").Value,
ClassID = item.Element("ClassID").Value,
Subheading = "",
Title = item.Element("Title").Value,
UpdateTime = item.Element("UpdateTime").Value,
CreateTime = item.Element("CreateTime").Value,
LinkUrl = item.Element("LinkUrl").Value,
ChannelDir = item.Element("ChannelDir").Value,
}
);
data = items.ToList();
return data.Cast<IWebRequestEntity>().ToList();
}
#endregion
}
}
作者:仓储大叔,张占岭,
荣誉:微软MVP