.NET平台把其它域名下的数据表内容列出来,比如新闻表(两个网站不在同一服务器)
首先,为了安全起见,服务器的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}
}
浙公网安备 33010602011771号