Posts Tagged ‘的类’

ASP.NET中实现中文简/繁体自动转换的类

星期二, 06月 3rd, 2008

在中文网站开发中,为了满足台湾/香港等有中文繁体阅读习惯de用户,很多网站需要实现中文简/繁体转换.

当然在实际de开发中,还要注意网站de图片上如果有中文de,也需要根据当前显示de是简体,还是繁体进行切换,否则无法达到效果!在本文中,我只帖上汉字转换de相关代码.如果有不清楚怎么调用de,请在我deBlog下留下Email.我直接把调用相关代码例子发给您!

注意:如在实际应用中,发现有本例子字库以外de汉字,可以自己添加,繁体简体对应字在_sGB和_tGB中de对应位置要一致!否则转换会出问题!

相关代码例子:


/// <summary>
/// G2B5Filter de摘要说明.
/// 将GB2312字符和Big5字符进行对照转换
/// 作者: 程式猎人 2003-06-24
/// </summary>
public class G2B5Filter : Stream
{
private Stream _sink;
private long _position;
private const string _sGB=@”皑蔼碍爱袄奥坝罢摆败颁办绊帮绑镑谤剥饱宝报鲍辈贝钡狈备惫绷笔毕毙币闭边编贬变辩辫标鳖别瘪濒滨宾摈饼并拨钵铂驳卜补财参蚕残惭惨灿苍舱仓沧厕侧册测层诧搀掺蝉馋谗缠铲产阐颤场尝长偿肠厂畅钞车彻尘陈衬撑称惩诚骋痴迟驰耻齿炽冲虫宠畴踌筹绸丑橱厨锄雏础储触处传疮闯创锤纯绰辞词赐聪葱囱从丛凑蹿窜错达带贷担单郸掸胆惮诞弹当挡党荡档捣岛祷导盗灯邓敌涤递缔颠点垫电淀钓调谍叠钉顶锭订丢东动栋冻斗犊独读赌镀锻断缎兑队对吨顿钝夺堕鹅额讹恶饿儿尔饵贰发罚阀珐矾钒烦范贩饭访纺飞诽废费纷坟奋愤粪丰枫锋风疯冯缝讽凤肤辐抚辅赋复负讣妇缚该钙盖干赶秆赣冈刚钢纲岗镐搁鸽阁铬个给龚宫巩贡钩沟构购够蛊顾剐挂关观馆惯贯广规硅归龟闺轨诡柜贵刽辊滚锅国过骇韩汉号阂鹤贺横轰鸿红后壶护沪户哗华画划话怀坏欢环还缓换唤痪焕涣黄谎挥辉毁贿秽会烩汇讳诲绘荤浑伙获货祸击机积饥迹讥鸡绩缉极辑级挤几蓟剂济计记际继纪夹荚颊贾钾价驾歼监坚笺间艰缄茧检碱硷拣捡简俭减荐槛鉴践贱见键舰剑饯渐溅涧将浆蒋桨奖讲酱胶浇骄娇搅铰矫侥脚饺缴绞轿较阶节杰洁结诫届紧锦仅谨进晋烬尽劲荆茎鲸惊经颈静镜径痉竞净纠厩旧驹举据锯惧剧鹃绢觉决诀绝钧军骏开凯颗壳课垦恳抠库裤夸块侩宽矿旷况亏岿窥馈溃扩阔蜡腊莱来赖蓝栏拦篮阑兰澜谰揽览懒缆烂滥捞劳涝乐镭垒类泪篱离里鲤礼丽厉励砾历沥隶俩联莲连镰怜涟帘敛脸链恋炼练粮凉两辆谅疗辽镣猎临邻鳞凛赁龄铃凌灵岭领馏刘龙聋咙笼垄拢陇楼娄搂篓芦卢颅庐炉”
“掳卤虏鲁赂禄录陆驴吕铝侣屡缕虑滤绿峦挛孪滦乱抡轮伦仑沦纶论萝罗逻锣箩骡骆络妈玛码蚂马骂吗买麦卖迈脉瞒馒蛮满谩猫锚铆贸么霉没镁门闷们锰梦谜弥觅幂绵缅庙灭悯闽鸣铭谬谋亩钠纳难挠脑恼闹馁内拟腻撵捻酿鸟聂啮镊镍柠狞宁拧泞钮纽脓浓农疟诺欧鸥殴呕沤盘庞抛赔喷鹏骗飘频贫苹凭评泼颇扑铺朴谱栖凄脐齐骑岂启气弃讫牵扦铅迁签谦钱钳潜浅谴堑枪呛墙蔷强抢锹桥乔侨翘窍窃钦亲寝轻氢倾顷请庆琼穷趋区躯驱龋颧权劝却鹊确让饶扰绕热韧认纫荣绒软锐闰润洒萨鳃赛叁伞丧骚扫涩杀纱筛晒删闪陕赡缮伤赏烧绍赊摄慑设绅审婶肾渗声绳胜圣师狮湿诗尸时蚀实识驶势适释饰视试寿兽枢输书赎属术树竖数帅双谁税顺说硕烁丝饲耸怂颂讼诵擞苏诉肃虽随绥岁孙损笋缩琐锁獭挞态摊贪瘫滩坛谭谈叹汤烫涛绦讨腾誊锑题体屉条贴铁厅听烃铜统头秃图涂团颓蜕脱鸵驮驼椭洼袜弯湾顽万网韦违围为潍维苇伟伪纬谓卫温闻纹稳问瓮挝蜗涡窝卧呜钨乌污诬无芜吴坞雾务误锡牺袭习铣戏细虾辖峡侠狭厦吓鲜纤咸贤衔闲显险现献县馅羡宪线厢镶乡详响项萧嚣销晓啸蝎协挟携胁谐写泻谢锌衅兴汹锈绣虚嘘须许叙绪续轩悬选癣绚学勋询寻驯训讯逊压鸦鸭哑亚讶阉烟盐严颜阎艳厌砚彦谚验鸯杨扬疡阳痒养样瑶摇尧遥窑谣药爷页业叶医铱颐遗仪蚁艺亿忆义诣议谊译异绎荫阴银饮隐樱婴鹰应缨莹萤营荧蝇赢颖哟拥佣痈踊咏涌优忧邮铀犹诱舆鱼渔娱与屿语吁御狱誉预驭鸳渊辕园员圆缘远愿约跃钥岳粤悦阅云郧匀陨运蕴酝晕韵杂灾载攒暂赞赃脏凿枣责择则泽贼赠扎”
“札轧铡闸栅诈斋债毡盏斩辗崭栈战绽张涨帐账胀赵蛰辙锗这贞针侦诊镇阵挣睁狰争帧郑证织职执纸挚掷帜质滞钟终种肿众诌轴皱昼骤猪诸诛烛瞩嘱贮铸筑驻专砖转赚桩庄装妆壮状锥赘坠缀谆着浊兹资渍踪综总纵邹诅组钻亘芈啬厍厣靥赝匦匮赜刭刿剀伛伥伧伫侪侬俦俨俪俣偾偬偻傥傧傩佥籴黉冁凫兖衮亵脔禀冢讦讧讪讴讵讷诂诃诋诏诒诓诔诖诘诙诜诟诠诤诨诩诮诰诳诶诹诼诿谀谂谄谇谌谏谑谒谔谕谖谙谛谘谝谟谠谡谥谧谪谫谮谯谲谳谵谶卺陉陧邝邬邺郏郐郓郦刍奂劢巯垩圹坜垆垭垲埘埚埙芗苈苋苌苁苎茏茑茔茕荛荜荞荟荠荦荥荩荪荭莳莴莅莸莺萦蒇蒉蒌蓦蓠蓣蔹蔺蕲薮藓奁尴扪抟挢掴掼揿摅撄撷撸撺叽呒呓呖呗咛哒哓哔哕哙哜哝唛唠唢啧啭喽喾嗫嗳辔嘤噜囵帏帱帻帼岖岘岚峄峤峥崂崃嵘嵛嵝巅徕犷狯狲猃猡猕饧饨饩饪饫饬饴饷饽馀馄馊馍馐馑馔庑赓廪忏怃怄忾怅怆怿恸恹恻恺恽悭惬愠愦懔闩闫闱闳闵闶闼闾阃阄阆阈阊阌阍阏阒阕阖阗阙阚沣沩泷泸泺泾浃浈浍浏浒浔涞涠渎渑渖渌溆滟滠滢滗潆潇潋潴濑灏骞迩迳逦屦弪妩妪妫姗娅娆娈娲娴婵媪嫒嫔嫱嬷驵驷驸驺驿驽骀骁骅骈骊骐骒骓骖骘骛骜骝骟骠骢骣骥骧纡纣纥纨纩纭纰纾绀绁绂绉绋绌绗绛绠绡绨绫绮绯绲缍绶绺绻绾缁缂缃缇缈缋缌缏缑缒缗缙缜缛缟缡缢缣缤缥缦缧缪缫缬缭缯缱缲缳缵玑玮珏珑顼玺珲琏瑷璎璇瓒韪韫韬杩枥枨枞枭栉栊栌栀栎柽桠桡桢桤桦桧栾棂椟椠椤椁榄榇榈榉槟槠樯橥橹橼檐檩殁殇殒殓殚殡轫轭轲轳轵轶轸轹轺轼轾辁辂辄辇辋辍辎辏辘辚戋戗戬瓯昙晔晖暧贲贳贶贻贽”
“赀赅赆赈赉赇赕赙觇觊觋觌觎觏觐觑毵氇氩氲牍胧胪胫脍脶腌腽膑欤飑飒飓飕飙毂齑斓炀炜炖烨焖焘祢祯禅怼悫愍懑戆沓泶矶砀砗砺砻硖硗碛碜龛睐睑畲罴羁钆钇钋钊钌钍钏钐钔钗钕钛钣钤钫钪钭钬钯钰钲钴钶钸钹钺钼钽钿铄铈铉铊铋铌铍铎铐铑铒铕铖铗铙铛铟铠铢铤铥铧铨铪铩铫铮铯铳铴铵铷铹铼铽铿锂锆锇锉锊锒锓锔锕锖锛锞锟锢锩锬锱锲锴锶锷锸锼锾镂锵镆镉镌镏镒镓镔镖镗镘镙镛镞镟镝镡镤镦镧镨镪镫镬镯镱镳锺穑鸠鸢鸨鸩鸪鸫鸬鸲鸱鸶鸸鸷鸹鸺鸾鹁鹂鹄鹆鹇鹈鹉鹌鹎鹑鹕鹗鹞鹣鹦鹧鹨鹩鹪鹫鹬鹭鹳疖疠痨痫瘅瘗瘿瘾癞癫窦窭裆裢裣裥褛褴襁皲耧聍聩顸颀颃颉颌颏颔颚颛颞颟颡颢颦虬虮虿蚬蚝蛎蛏蛱蛲蛳蛴蝈蝾蝼罂笃笕笾筚筝箦箧箨箪箫篑簖籁舣舻袅羟糁絷麸趱酽酾鹾趸跄跖跞跷跸跹跻踬踯蹑蹒蹰躏躜觞觯靓雳霁霭龀龃龅龆龇龈龉龊龌黾鼋鼍隽雠銮錾鱿鲂鲅鲈稣鲋鲎鲐鲒鲔鲕鲚鲛鲞鲟鲠鲡鲢鲣鲥鲦鲧鲨鲩鲫鲭鲮鲰鲱鲲鲳鲵鲶鲷鲻鲽鳄鳅鳆鳇鳌鳍鳎鳏鳐鳓鳔鳕鳗鳜鳝鳟鳢鞑鞯鹘髅髋髌魇魉飨餍鬓黩黪鼹”;
private const string _tGB=@”皚藹礙愛襖奧壩罷擺敗頒辦絆幫綁鎊謗剝飽寶報鮑輩貝鋇狽備憊繃筆畢斃幣閉邊編貶變辯辮標鱉別癟瀕濱賓擯餅並撥缽鉑駁蔔補財參蠶殘慚慘燦蒼艙倉滄廁側冊測層詫攙摻蟬饞讒纏鏟產闡顫場嘗長償腸廠暢鈔車徹塵陳襯撐稱懲誠騁癡遲馳恥齒熾沖蟲寵疇躊籌綢醜櫥廚鋤雛礎儲觸處傳瘡闖創錘純綽辭詞賜聰蔥囪從叢湊躥竄錯達帶貸擔單鄲撣膽憚誕彈當擋黨蕩檔搗島禱導盜燈鄧敵滌遞締顛點墊電澱釣調諜疊釘頂錠訂丟東動棟凍鬥犢獨讀賭鍍鍛斷緞兌隊對噸頓鈍奪墮鵝額訛惡餓兒爾餌貳發罰閥琺礬釩煩範販飯訪紡飛誹廢費紛墳奮憤糞豐楓鋒風瘋馮縫諷鳳膚輻撫輔賦複負訃婦縛該鈣蓋幹趕稈贛岡剛鋼綱崗鎬擱鴿閣鉻個給龔宮鞏貢鉤溝構購夠蠱顧剮掛關觀館慣貫廣規矽歸龜閨軌詭櫃貴劊輥滾鍋國過駭韓漢號閡鶴賀橫轟鴻紅後壺護滬戶嘩華畫劃話懷壞歡環還緩換喚瘓煥渙黃謊揮輝毀賄穢會燴彙諱誨繪葷渾夥獲貨禍擊機積饑跡譏雞績緝極輯級擠幾薊劑濟計記際繼紀夾莢頰賈鉀價駕殲監堅箋間艱緘繭檢堿鹼揀撿簡儉減薦檻鑒踐賤見鍵艦劍餞漸濺澗將漿蔣槳獎講醬膠澆驕嬌攪鉸矯僥腳餃繳絞轎較階節傑潔結誡屆緊錦僅謹進晉燼盡勁荊莖鯨驚經頸靜鏡徑痙競淨糾廄舊駒舉據鋸懼劇鵑絹覺決訣絕鈞軍駿開凱顆殼課墾懇摳庫褲誇塊儈寬礦曠況虧巋窺饋潰擴闊蠟臘萊來賴藍欄攔籃闌蘭瀾讕攬覽懶纜爛濫撈勞澇樂鐳壘類淚籬離裏鯉禮麗厲勵礫曆瀝隸倆聯蓮連鐮憐漣簾斂臉鏈戀煉練糧涼兩輛諒療遼鐐獵臨鄰鱗凜賃齡鈴淩靈嶺領餾劉龍聾嚨籠壟攏隴樓婁摟簍蘆盧顱廬爐”
“擄鹵虜魯賂祿錄陸驢呂鋁侶屢縷慮濾綠巒攣孿灤亂掄輪倫侖淪綸論蘿羅邏鑼籮騾駱絡媽瑪碼螞馬罵嗎買麥賣邁脈瞞饅蠻滿謾貓錨鉚貿麼黴沒鎂門悶們錳夢謎彌覓冪綿緬廟滅憫閩鳴銘謬謀畝鈉納難撓腦惱鬧餒內擬膩攆撚釀鳥聶齧鑷鎳檸獰甯擰濘鈕紐膿濃農瘧諾歐鷗毆嘔漚盤龐拋賠噴鵬騙飄頻貧蘋憑評潑頗撲鋪樸譜棲淒臍齊騎豈啟氣棄訖牽扡鉛遷簽謙錢鉗潛淺譴塹槍嗆牆薔強搶鍬橋喬僑翹竅竊欽親寢輕氫傾頃請慶瓊窮趨區軀驅齲顴權勸卻鵲確讓饒擾繞熱韌認紉榮絨軟銳閏潤灑薩鰓賽三傘喪騷掃澀殺紗篩曬刪閃陝贍繕傷賞燒紹賒攝懾設紳審嬸腎滲聲繩勝聖師獅濕詩屍時蝕實識駛勢適釋飾視試壽獸樞輸書贖屬術樹豎數帥雙誰稅順說碩爍絲飼聳慫頌訟誦擻蘇訴肅雖隨綏歲孫損筍縮瑣鎖獺撻態攤貪癱灘壇譚談歎湯燙濤絛討騰謄銻題體屜條貼鐵廳聽烴銅統頭禿圖塗團頹蛻脫鴕馱駝橢窪襪彎灣頑萬網韋違圍為濰維葦偉偽緯謂衛溫聞紋穩問甕撾蝸渦窩臥嗚鎢烏汙誣無蕪吳塢霧務誤錫犧襲習銑戲細蝦轄峽俠狹廈嚇鮮纖鹹賢銜閑顯險現獻縣餡羨憲線廂鑲鄉詳響項蕭囂銷曉嘯蠍協挾攜脅諧寫瀉謝鋅釁興洶鏽繡虛噓須許敘緒續軒懸選癬絢學勳詢尋馴訓訊遜壓鴉鴨啞亞訝閹煙鹽嚴顏閻豔厭硯彥諺驗鴦楊揚瘍陽癢養樣瑤搖堯遙窯謠藥爺頁業葉醫銥頤遺儀蟻藝億憶義詣議誼譯異繹蔭陰銀飲隱櫻嬰鷹應纓瑩螢營熒蠅贏穎喲擁傭癰踴詠湧優憂郵鈾猶誘輿魚漁娛與嶼語籲禦獄譽預馭鴛淵轅園員圓緣遠願約躍鑰嶽粵悅閱雲鄖勻隕運蘊醞暈韻雜災載攢暫贊贓髒鑿棗責擇則澤賊贈紮”
“劄軋鍘閘柵詐齋債氈盞斬輾嶄棧戰綻張漲帳賬脹趙蟄轍鍺這貞針偵診鎮陣掙睜猙爭幀鄭證織職執紙摯擲幟質滯鍾終種腫眾謅軸皺晝驟豬諸誅燭矚囑貯鑄築駐專磚轉賺樁莊裝妝壯狀錐贅墜綴諄著濁茲資漬蹤綜總縱鄒詛組鑽亙羋嗇厙厴靨贗匭匱賾剄劌剴傴倀傖佇儕儂儔儼儷俁僨傯僂儻儐儺僉糴黌囅鳧兗袞褻臠稟塚訐訌訕謳詎訥詁訶詆詔詒誆誄詿詰詼詵詬詮諍諢詡誚誥誑誒諏諑諉諛諗諂誶諶諫謔謁諤諭諼諳諦諮諞謨讜謖諡謐謫譾譖譙譎讞譫讖巹陘隉鄺鄔鄴郟鄶鄆酈芻奐勱巰堊壙壢壚埡塏塒堝塤薌藶莧萇蓯苧蘢蔦塋煢蕘蓽蕎薈薺犖滎藎蓀葒蒔萵蒞蕕鶯縈蕆蕢蔞驀蘺蕷蘞藺蘄藪蘚奩尷捫摶撟摑摜撳攄攖擷擼攛嘰嘸囈嚦唄嚀噠嘵嗶噦噲嚌噥嘜嘮嗩嘖囀嘍嚳囁噯轡嚶嚕圇幃幬幘幗嶇峴嵐嶧嶠崢嶗崍嶸崳嶁巔徠獷獪猻獫玀獼餳飩餼飪飫飭飴餉餑餘餛餿饃饈饉饌廡賡廩懺憮慪愾悵愴懌慟懨惻愷惲慳愜慍憒懍閂閆闈閎閔閌闥閭閫鬮閬閾閶閿閽閼闃闋闔闐闕闞灃溈瀧瀘濼涇浹湞澮瀏滸潯淶潿瀆澠瀋淥漵灩灄瀅潷瀠瀟瀲瀦瀨灝騫邇逕邐屨弳嫵嫗媯姍婭嬈孌媧嫻嬋媼嬡嬪嬙嬤駔駟駙騶驛駑駘驍驊駢驪騏騍騅驂騭騖驁騮騸驃驄驏驥驤紆紂紇紈纊紜紕紓紺絏紱縐紼絀絎絳綆綃綈綾綺緋緄綞綬綹綣綰緇緙緗緹緲繢緦緶緱縋緡縉縝縟縞縭縊縑繽縹縵縲繆繅纈繚繒繾繰繯纘璣瑋玨瓏頊璽琿璉璦瓔璿瓚韙韞韜榪櫪棖樅梟櫛櫳櫨梔櫟檉椏橈楨榿樺檜欒欞櫝槧欏槨欖櫬櫚櫸檳櫧檣櫫櫓櫞簷檁歿殤殞殮殫殯軔軛軻轤軹軼軫轢軺軾輊輇輅輒輦輞輟輜輳轆轔戔戧戩甌曇曄暉曖賁貰貺貽贄”
“貲賅贐賑賚賕賧賻覘覬覡覿覦覯覲覷毿氌氬氳牘朧臚脛膾腡醃膃臏歟颮颯颶颼飆轂齏斕煬煒燉燁燜燾禰禎禪懟愨湣懣戇遝澩磯碭硨礪礱硤磽磧磣龕睞瞼佘羆羈釓釔釙釗釕釷釧釤鍆釵釹鈦鈑鈐鈁鈧鈄鈥鈀鈺鉦鈷鈳鈽鈸鉞鉬鉭鈿鑠鈰鉉鉈鉍鈮鈹鐸銬銠鉺銪鋮鋏鐃鐺銦鎧銖鋌銩鏵銓鉿鎩銚錚銫銃鐋銨銣鐒錸鋱鏗鋰鋯鋨銼鋝鋃鋟鋦錒錆錛錁錕錮錈錟錙鍥鍇鍶鍔鍤鎪鍰鏤鏘鏌鎘鐫鎦鎰鎵鑌鏢鏜鏝鏍鏞鏃鏇鏑鐔鏷鐓鑭鐠鏹鐙鑊鐲鐿鑣鍾穡鳩鳶鴇鴆鴣鶇鸕鴝鴟鷥鴯鷙鴰鵂鸞鵓鸝鵠鵒鷳鵜鵡鵪鵯鶉鶘鶚鷂鶼鸚鷓鷚鷯鷦鷲鷸鷺鸛癤癘癆癇癉瘞癭癮癩癲竇窶襠褳襝襇褸襤繈皸耬聹聵頇頎頏頡頜頦頷顎顓顳顢顙顥顰虯蟣蠆蜆蠔蠣蟶蛺蟯螄蠐蟈蠑螻罌篤筧籩篳箏簀篋籜簞簫簣籪籟艤艫嫋羥糝縶麩趲釅釃鹺躉蹌蹠躒蹺蹕躚躋躓躑躡蹣躕躪躦觴觶靚靂霽靄齔齟齙齠齜齦齬齪齷黽黿鼉雋讎鑾鏨魷魴鮁鱸穌鮒鱟鮐鮚鮪鮞鱭鮫鯗鱘鯁鱺鰱鰹鰣鰷鯀鯊鯇鯽鯖鯪鯫鯡鯤鯧鯢鯰鯛鯔鰈鱷鰍鰒鰉鼇鰭鰨鰥鰩鰳鰾鱈鰻鱖鱔鱒鱧韃韉鶻髏髖髕魘魎饗饜鬢黷黲鼴”;

public G2B5Filter(Stream sink)
{
//System.Web.HttpContext.Current.Response.ContentEncoding=Encoding.GetEncoding(950);
_sink = sink;

}

// The following members of Stream must be overriden.
public override bool CanRead
{
get { return true; }
}

public override bool CanSeek
{
get { return true; }
}

public override bool CanWrite
{
get { return true; }
}

public override long Length
{
get { return 0; }
}

public override long Position
{
get { return _position; }
set { _position = value; }
}

public override long Seek(long offset, System.IO.SeekOrigin direction)
{
return _sink.Seek(offset, direction);
}

public override void SetLength(long length)
{
_sink.SetLength(length);
}

public override void Close()
{
_sink.Close();
}

public override void Flush()
{
_sink.Flush();
}

public override int Read(byte[] buffer, int offset, int count)
{
return _sink.Read(buffer, offset, count);
}
/// <summary>
/// 实际处理字符替换de作业,将简体字和繁体字进行替换.
/// </summary>
/// <param name=”buffer”> </param>
/// <param name=”offset”></param>
/// <param name=”count”></param>
public override void Write(byte[] buffer, int offset, int count)
{
Encoding e=Encoding.GetEncoding(936); //936是GB2312编码,950是Big5编码

string str=e.GetString(buffer,offset,count);
for(int i=0;i<str.Length;i )
{
int j=_sGB.IndexOf(str[i]);
if(j!=-1)str=str.Replace(_sGB[j],_tGB[j]);
}
e=Encoding.GetEncoding(System.Web.HttpContext.Current.Response.Charset);
_sink.Write(e.GetBytes(str), 0, e.GetByteCount(str));
}

}

public class EncodingFilter
{
Page thisPage;

public EncodingFilter(Page mPage)
{
thisPage=mPage;
}

/// <summary>
/// 对输入de流对象进行编码,然后Write
/// </summary>
/// <param name=”EncodingStyle”></param>
public void G2BEncoding(string EncodingStyle)
{
//======================== 公共函数 Start =============================
thisPage.Response.ContentEncoding=Encoding.GetEncoding(”GB2312″);

if(EncodingStyle==”BIG5″)
{
thisPage.Response.Filter = new G2B5Filter(thisPage.Response.Filter);
thisPage.Response.Charset=”BIG5″;
}

if(EncodingStyle==”GB2312″)
{
thisPage.Response.Charset=”GB2312″;
}
//======================== 公共函数 End =============================
}
}

一个分页的类及调用的例子

星期一, 06月 2nd, 2008

//PageCt.java 分页de类
/*
*** @version ***********
*** Created on 2001年6月25日, 下午14:41
**************************************
*/
package vod;
import java.sql.*;
import java.util.*;

public class PageCt
{
private long l_start; //开始纪录
private long l_end; //结束纪录
private long l_curpage; //当前页数
private long l_totalnum;//总记录数
private int int_num=5; //每页10条
private long l_totalpage; //总de页数

public void Init(long currentpage,long totalnum)
{
l_curpage = currentpage;
l_totalnum = totalnum;

if (currentpage>=0)
{
if (currentpage>=(long)Math.ceil((double)l_totalnum/(double)int_num))
l_curpage = (long)Math.floor((double)l_totalnum/(double)int_num);
else
l_curpage = currentpage;
}
else
{
l_curpage = 0;
}
l_start = l_curpage * int_num;
l_end = l_start int_num;
if (l_end > l_totalnum)
l_end = l_totalnum;
l_totalpage = (long)Math.ceil((double)l_totalnum/(double)int_num);
}
public long getCurpage()
{
return l_curpage;
}
public long getPrepage()
{
if (l_curpage-1>=0)
{
return l_curpage-1;
}
else
{
return 0;
}
}
public long getNextpage()
{
if (l_curpage 1<=l_totalpage)
{
return l_curpage 1;
}
else
{
return l_totalpage;
}
}
public long getTotalnum()
{
return l_totalnum;
}
public long getTotalpage()
{
return l_totalpage;
}
public long getStart()
{
return l_start;
}
public long getEnd()
{
return l_end;
}

};
===============================================
//调用例子
<%
/*
*** @author 马毅 ***********
*** @version ***********
*** Created on 2001年6月12日, 下午17:13
**************************************
*/
<%@ page import=”java.sql.*”%>
<%@ page import=”java.lang.*”%>
<%@ page contentType=”text/html;charset=gb2312″ %>
<jsp:useBean id=”PageCount” scope=”page” class=”kstest.PageCt” />
<jsp:useBean id=”sqlbean” scope=”page” class=”vod.sql_data” />
<html>
<head>
<TITLE>测试</TITLE>
<STYLE>
body,table{font-size:9pt}
A:link {
COLOR: #000084; TEXT-DECORATION: none
}
A:visited {
COLOR: #000084; TEXT-DECORATION: none
}
A:hover {
COLOR: black; TEXT-DECORATION: underline
}
.ourfont {
FONT-SIZE: 9pt
}
</STYLE>
</head>
<body bgcolor=#eff3ff>
<center>
<font color=#000084><h3>Test for Test</h3></font>
<hr width=600 color=#b5dbff>
<br>
<%
ResultSet rs0 = sqlbean.executeQuery(”select count(*) from UserList );
rs0.next();
long data_num=rs0.getLong(1);
long Current_Page = 0;
String currentpage=(String)request.getParameter(”currentpage”);
if (currentpage != null && !currentpage.equals(”"))
{
Current_Page = Integer.parseInt(request.getParameter(”currentpage”));
}
String Query_Page=(String)request.getParameter(”Query_Page”);
if (Query_Page!=null && !Query_Page.equals(”"))
{
Current_Page = Integer.parseInt(request.getParameter(”Query_Page”))-1;
}
PageCt.Init(Current_Page,data_num);
long l_start = PageCt.getStart();
long l_end = PageCt.getEnd();
//查询记录
ResultSet rs = sqlbean.executeQuery(”select * from UserList ” );
long i=0;
while((i<l_start) && rs.next())
{
i ;
}
//输出查询结果
long j=0;
while(rs.next() && (i<l_end))
{
j=i 1;
String col2 = rs.getString(2);
String col3 = rs.getString(3);
String col4 = rs.getString(4);
String col5 = rs.getString(5);
String col6 = rs.getString(6);
String col7 = rs.getString(7);
String col8 = rs.getString(8);
//打印所显示de数据
out.println(”<table border=0 width=600>”);
out.println(”<tr><td colspan=2><font color=#000084>” j “、” (col2==null?”":col2) “</font></td></tr><tr><td colspan=2>答案:” (col3==null?”":col3) “</td></tr>”);
out.println(”<tr><td> 选项1:” (col4==null?”":col4) “</td><td> 选项2:” (col5==null?”":col5) “</td></tr>”);
out.println(”<tr><td> 选项3:” (col6==null?”":col6) “</td><td> 选项4:” (col7==null?”":col7) “</td></tr>”);
if (col8!=null && !col8.equals(”"))
{
out.println(”<tr><td colspan=2>备注:” col8 “</td></tr>”);
}
out.println(”</table><br>”);
i ;
}
%>
<table width=600>
<tr bgcolor=#b5dbff>
<form method=GET action=index.jsp>
<td width=80 align=center valign=bottom>共 <%=PageCt.getTotalnum()%> 条</td>
<td width=80 align=center valign=bottom><%=PageCt.getCurpage() 1%>/<%=PageCt.getTotalpage()%> 页</td>
<td width=120 align=center>查看第 <input type=text name=Query_Page size=3> 页</td>
<td width=50 align=center valign=bottom><a href=index.jsp?currentpage=<%=PageCt.getPrepage()%>>上页</a></td>
<td width=50 align=center valign=bottom><a href=index.jsp?currentpage=<%=PageCt.getNextpage()%>>下页</a>
</td>
</tr>
</table>
<br><br><br>
<table cellspacing=20>
<tr>
<td>问题包含<input type=text name=question_str size=10 value=<% if (question_str != null) out.println(question_str); %> ></td>
<td>答案包含<input type=text name=answer_str size=10 value=<% if (answer_str != null) out.println(answer_str); %> ></td>
<td>选项包含<input type=text name=sel_str size=10 value=<% if (sel != null) out.println(sel); %> ></td>
</tr>
<tr>
<td colspan=3 align=center><input type=submit value=查询></td>
</tr>
</form>
</table>
<br><br>
<a href=”insert.jsp”>添加</a>
<center>
</body>
</html>

利用PHP实现与ASP Banner组件相似的类

星期一, 06月 2nd, 2008

<?php
/*******************************************************
作者: 吴振亨 (Biz)–phpscript
E-mail:wuzhenheng@china.com
web: http://phpscript.osh.com.cn
文件名:AdRotator.class.php3
版权声明:
如果您使用了本文件,请给作者写一封E-mail
如有问题欢迎与作者联系
谢谢您de关注!
********************************************************/
/*
广告条管理程序
public method
GetAdvertisement($adfile)
parameters
Target=
Width=
Height=
Border=
Redirect=
*/
class AdRotator {
var $Target="_blank";
var $Width="460";
var $Height="60";
var $Border=0;
var $Redirect="";
var $BannerData=array ();
var $RandTemp=1;
function AdRotator()
{
}
/*
public
返回广告de链接字串
*/
function GetAdvertisement($adfile)
{
if(count($this->BannerData)==0)
{
$this->BannerData=$this->ReadAdFile($adfile);
}
$AdData=$this->BannerData;
$uplimited=count($AdData);
//随机产生一个ID
srand((double)microtime()*1000000000000000000);
$id=@rand(1,$uplimited);
while($this->RandTemp==$id)
{
srand((double)microtime()*1000000000000000000);
//$id=@rand(1,count($AdData));
$id=@rand(1,$uplimited);
}
$this->RandTemp=$id;
//echo $id;
//echo count($AdData);
//echo $AdData[5]["image"];

$LinkString=" <a href="".$this->Redirect;
$LinkString.="?url=".$AdData[$id]["url"];
$LinkString.="" Target="".$this->Target;
$LinkString.="" Title="".$AdData[$id]["title"];
$LinkString.="" >";
$LinkString.=" <img border="".$this->Border;
$LinkString.="" src="".$AdData[$id]["image"];
$LinkString.="" width="".$this->Width;
$LinkString.="" height="".$this->Height;
$LinkString.="" >";
$LinkString.="</a>";
//echo $LinkString;
return $LinkString;
}
/*
private
读入文件de基本设置
*/
function ReadAdFile($adfile)
{
$FP=fopen($adfile,"r");
while($buffer=@fgets($FP,1024))
{
if(!eregi("#",$buffer))
{
if(eregi("^*",$buffer))
{
$switchto="off";
}
$SetTemp=split("=",$buffer);
if($switchto=="")
{
switch ($SetTemp[0])
{
case "REDIRECT":
$this->Redirect=$SetTemp[1];
break;
case "WIDTH":
$this->WIDTH=$SetTemp[1];
break;
case "HEIGHT":
$this->HEIGHT=$SetTemp[1];
break;
case "BORDER":
$this->BORDER=$SetTemp[1];
break;
case "TARGET":
$this->Target=$SetTemp[1];
break;
}
}
else
{
switch ($SetTemp[0])
{
case "image":
$i ;
$BannerData[$i]["image"]=$SetTemp[1];
//echo "<br>";echo $buffer;echo $SetTemp[1];
//echo $BannerData[$i]["image"];
break;
case "url":
$BannerData[$i]["url"]=$SetTemp[1];
break;
case "title":
$BannerData[$i]["title"]=$SetTemp[1];
break;
case "rate":
$BannerData[$i]["rate"]=$SetTemp[1];
break;
}//end of switch
}//end of if($switch)
}//end of if(#)
}//end of while
return $BannerData;
}//end of function
}//end of class
/*
使用方法
广告设置文件书写格式banner.txt
——开始—
REDIRECT=./adredir.asp
WIDTH=468
HEIGHT=60
BORDER=0
*
#注释
#某某公司广告1
image=../banner/1.gif
url=http://www.asps0ite.com1
title=One
rate=30
—-结束—–
说明:
与ASPde广告组件相仿
*表示设置,其他为图片de设置 #:表示注释
—-使用—–
$banner=new AdRotator();
echo $banner->GetAdvertisement("./banner.txt");
echo $banner->GetAdvertisement("./banner.txt");
echo $banner->GetAdvertisement("./banner.txt");
*/
?>
【本文版权归作者与奥索网共同拥有,如需转载,请注明作者及出处】

给多个地址发邮件的类

星期一, 06月 2nd, 2008

<?php
////////////////////////////////////////////////////////////
// EmailClass 0.5
// class for sending mail
//
// Paul Schreiber
// php@paulschreiber.com
// http://paulschreiber.com/
//
// parameters
// ———-
// - subject, message, senderName, senderEmail and toList are required
// - ccList, bccList and replyTo are optional
// - toList, ccList and bccList can be strings or arrays of strings
// (those strings should be valid email addresses
//
// example
// ——-
// $m = new email ( "hello there", // subject
// "how are you?", // message body
// "paul", // sender’s name
// "foo@foobar.com", // sender’s email
// array("paul@foobar.com", "foo@bar.com"), // To: recipients
// "paul@whereever.com" // Cc: recipient
// );
//
// print "mail sent, result was" . $m->send();
//
//
//
if ( ! defined( ‘MAIL_CLASS_DEFINED’ ) ) {
define(’MAIL_CLASS_DEFINED’, 1 );
class email {
// the constructor!
function email ( $subject, $message, $senderName, $senderEmail, $toList, $ccList=0, $bccList=0, $replyTo=0) {
$this->sender = $senderName . " <$senderEmail>";
$this->replyTo = $replyTo;
$this->subject = $subject;
$this->message = $message;
// set the To: recipient(s)
if ( is_array($toList) ) {
$this->to = join( $toList, "," );
} else {
$this->to = $toList;
}
// set the Cc: recipient(s)
if ( is_array($ccList) && sizeof($ccList) ) {
$this->cc = join( $ccList, "," );
} elseif ( $ccList ) {
$this->cc = $ccList;
}
// set the Bcc: recipient(s)
if ( is_array($bccList) && sizeof($bccList) ) {
$this->bcc = join( $bccList, "," );
} elseif ( $bccList ) {
$this->bcc = $bccList;
}
}
// send the message; this is actually just a wrapper for
// PHP’s mail() function; heck, it’s PHP’s mail function done right :-)
// you could override this method to:
// (a) use sendmail directly
// (b) do SMTP with sockets
function send () {
// create the headers needed by PHP’s mail() function
// sender
$this->headers = "From: " . $this->sender . "\n";
// reply-to address
if ( $this->replyTo ) {
$this->headers .= "Reply-To: " . $this->replyTo . "\n";
}
// Cc: recipient(s)
if ( $this->cc ) {
$this->headers .= "Cc: " . $this->cc . "\n";
}
// Bcc: recipient(s)
if ( $this->bcc ) {
$this->headers .= "Bcc: " . $this->bcc . "\n";
}
return mail ( $this->to, $this->subject, $this->message, $this->headers );
}
}

}
?>

PHP 中的类

星期一, 06月 2nd, 2008

PHP 中de类

在阐述类de概念之前我来先说说面向对象编程de概念:面向对象de程序设计(Object-Oriented Programming,简记为OOP)立意于创建软件重用相关代码,具备更好地模拟现实世界环境de能力,这使它被公认为是自上而下编程de优胜者.它通过给程序中加入扩展语句,把函数“封装”进编程所必需de“对象”中.面向对象de编程语言使得复杂de工作条理清晰、编写容易.说它是一场革命,不是对对象本身而言,而是对它们处理工作de能力而言.对象并不与传统程序设计和编程方法兼容,只是部分面向对象反而会使情形更糟.除非整个开发环境都是面向对象de,否则对象产生de好处还没有带来de麻烦多.有人可能会说PHP不是一个真正de面向对象编程de语言, PHP 是一个混合型 语言,您可以使用面向对象编程,也可以使用传统de过程化编程.然而,对于大型项目de开发,您可能想需要在PHP中使用纯de面向对象编程去声明类,而且在您de项目开发只用对象和类.随着项目越来越大,使用面向对象编程可能会有帮助,面向对象编程相关代码很容易维护,容易理解和重复使用,这些就是软件工程de基础.在基于Webde项目中应用这些概念就成为将来网站成功de关键.
对象(Object)是问题域或实现域中某些事物de一个抽象,它反映此事物在系统中需要保存de信息和发挥de作用;它是一组属性和有权对这些属性进行操作de一组服务de封装体. 关于对象要从两方面理解:一方面指系统所要处理de现实世界中de对象;另一方面对象是计算机不直接处理de对象,而是处理相应de计算机表示,这种计算机表示也称为对象.简单de来说,一个人就是一个对象,一个尺子也可以说是个对象.当这些对象可以用数据直接表示时,我就称他为属性,尺子de度量单位可以是厘米,公尺或英尺,这个度量单位就是尺子de属性.
在PHP里我可以定义一个类,类(Class)就是指变量与一些使用这些变量de函数de集合.PHP是一种松散类型de语言,所以通过类型重载不起作用,通过参数de个数不同来重载也不起作用. 有时在面向中重载构造函数非常好,这样您可以通过不同de方法创建对象(传递不同数量de参数).在PHP中就是通过类来实现de.
在PHP中是通过类来完成信息封装de,在PHP中定义类de语法是:
class Class_name // 在面向对象编程类中,习惯上类de第一个字符为大写,并且必须符合变量de命名规则.
{
//函数与变量de集合
}
?>
在定义类时您可以按自已de喜好de格式进行定义,但最好能保持一种标准,这样开发起来会更有效些.
数据成员在类中使用”var”声明来定义,在给数据成员赋值之前,它们是没有类型de.一个数据成员可以是一个整数,一个数组,一个相关数组(Associative Array)或者是一个对象.
下面是一个类定义de实际例子:
class Student
{
var $str_Name; //姓名
var $str_Sex; //性别
var $int_Id; //学号
var $int_English; //英语成绩
var $int_maths; //数学成绩
}
?>
这是一个很普通定义类de简单例子,用于显示学生de学习成绩,类名为Student,Student类包涵了一个学生de基本属性:姓名、性别、学号、英语成绩和数学成绩.
function我称之为在类中被定义de函数,在函数中访问类成员变量时,您应该使用$this->var_name,其中var_name指de是类中被声明de变量,否则对一个函数来说,它只能是局部变量. 我先定义一个Input()de函数,用来给实例中de对象赋以初值:
function Input ( $Name, $Sex, $Id, $Englis, $Maths)
{
$this->str_Name=$Name;
$this->str_Sex =$Sex;
$this->int_Id =$Id;
$this->int_Englis=$English;
$this->int_Maths=$Maths;
}
现在我再定义一个叫“ShowInfo()”de函数,用于打印学生de基本情况:
function ShowInfo() //定义ShowInfo()函数
{
echo (“姓名:$this->str_Name
”);
echo (“性别:$this->str_Sex
”);
echo (“学号:$this->int_Id
”);
echo (“英语成绩:$this->int_English
”);
echo (“数学成绩:$this->int_Maths
”);
}
而定义好de类则必须使用new关键词来生成对象:
$A_student=new Student;
例如我要为一个名为$Wingde对象创建实例,并进行赋值,可以使用下面de相关代码:
$Wing =new Student; //用new关键词来生成对象
$Wing ->Input (“Wing”,”男”,33,95,87);
//分别输入Wingde姓名、性别、学号、英语成绩、数学成绩,其中姓名和性别是字符型变量,所以需要用双引号,其它为数值型变量则不需要.
通过下面这段完整de源相关代码,我就可以很清楚de看到类在PHP是怎么被运用de:

class Student
{
var $str_Name;
var $str_Sex;
var $int_Id;
var $int_English;
var $int_maths;
function Input ( $Name, $Sex, $Id, $English, $Maths)
{
$this->str_Name=$Name;
$this->str_Sex =$Sex;
$this->int_Id =$Id;
$this->int_English=$English;
$this->int_Maths=$Maths;
}
function ShowInfo()
{
echo (“姓名:$this->str_Name
”);
echo (“性别:$this->str_Sex
”);
echo (“学号:$this->int_Id
”);
echo (“英语成绩:$this->int_English
”);
echo (“数学成绩:$this->int_Maths
”);
}
}

$Wing = new Student;
$Wing->Input (“Wing”,”男”,33,95,87);
$Paladin = new Student;
$Paladin->Input (“paladin”,”女”,38,58,59.5);
$Wing->ShowInfo();
$Paladin->ShowInfo();
?>
执行结果应是这样de:
姓名:Wing
性别:男
学号:33
英语成绩:95
数学成绩:87
姓名:Paladin
性别:女
学号:38
英语成绩:58
数学成绩:59.5
PHP现有de版本较以前de版本在对面向对象编程de支持方面有了很大de改善,但支持de还不是很完整,不过现阶段PHP对面向对象编程语言提供de支持不但有利于我设计程序de结构,对于对程序de维护也能提供很大de帮助.
全文出自 : cngnu

一棵php的类树(支持无限分类)

星期一, 06月 2nd, 2008

最近问无限分类de类树问题比较多,所以一高兴自己写了一个,我刚写完de,大家用用看,看看怎么实现起来更快,更简单,把您de树也贴出来(要只查询一次数据库de)<br>
这是一棵分类列表de类树, 支持无限分类<br>
一个分类下面可以同时有”包含子类de分类”和”最终分类”;<br>
唯一de优点是*****只需要进行一次de数据库*****查询.<br>
样子不是很好看,不过可以自定义修改,可以自己定义css加里面<br>
缓存方面还没有作,可以自己补上
下面例子de目录结构是这样de.
¦–Catagory.php <br>
¦–images—-tree.jsp <br>
¦–images—-treeopen.gif <br>
¦–images—-treeclose.gif <br>
¦–images—-line.gif <br>
/****************tree.jsp********************/
function expand(id){
node = document.all(’node’ id);
if(node.style.display==”){
node.style.display = ‘none’;
document.images(’img’ id).src = imgopen;
}else{
node.style.display = ”;
document.images(’img’ id).src = imgclose;
}
}
/****************Catagory.php********************/
<?php
define(’CATAGORY_TREE_EXPEND_NONE’,0);
define(’CATAGORY_TREE_EXPEND_ALL’,1);
class Catagory{
//基础分类数据
var $treeData = array();
//分类de等级结构数组,以分类deid值作为数组de关键字
var $treePList = array();
//自分类对应上级类de关系
var $treeCList = array();
/*
* 这个是大分类de模板
*
* __id__ 分类de编号
* __name__ 分类de名称
* __image__ 分类前面显示de图像名称 $imgOpen or $imgClose
* __open__ 分类当前是否是展开de
* __inner__ 子分类显示de位置

* 样式可以根据自己de需要任意修改 ,但是不能删除现有de元素
*/
var $blockTpl = ‘
<table border=”0″ cellpadding=”0″ cellspacing=”0″>
<tr>
<td colspan=”2″><a onclick=”expand(__id__); return false;” href=”#”>
<img src=”__image__” border=”0″ width=”15″ height=”15″ id=”img__id__”></a>
<a onclick=”expand(__id__); return false;” href=”#”>
__name__</a></td>
</tr>
<tr id=”node__id__” style=”display:__open__;”>
<td width=”20″></td><td>__inner__</td>
</tr>
</table>’;
/*
* 这个是小分类de模板
*
* see $blockTpl
*/
var $elementTpl = ‘<img src=”images/line.gif” width=”15″ height=”15″><a href=”?id=__id__”><font color=”white”>__name__</font></a><br/>’;
/*
* 这个是当前位置显示模板
*
* see $blockTpl
*/
var $currentTpl = ‘<a href=”?id=__id__”><font color=”white”>__name__</font></a>’;
var $js = “images/tree.js”;
var $imgOpen = ‘images/treeopen.gif’;
var $imgClose = ‘images/treeclose.gif’;
var $imgLine = ‘images/line.gif’;
var $cachFile = ”;
var $expand = 0;
var $result = array();
var $treeStr = ”;
var $currentStr = ”;
/*
* 用来初始化,传入分类数据
*
*param $data array()
*/
function Catagory(&$data){
$this->_init($data);
}
function _init($tmpData){
$plevel = $clevel = $treeData = array();

foreach($tmpData as $value){
$treeData[$value['id']] = $value;
$plevel[$value['pid']][$value['id']] = ‘END’;
$clevel[$value['id']] = $value['pid'];
}
$this->treeData = &$treeData;
$this->treePList = &$plevel;
$this->treeCList = &$clevel;
}
/*
* 解析分类列表
*
*param $cataId int 要解析de主分类de编号
*/
function parseNode($cataId=0){
$this->result = $this->treePList[$cataId];
if($this->result==null) die(”Catagory id error”);
$this->treeStr = $this->_doNode($this->result);
$this->treeStr .= $this->_jsParse();
}
function &_doNode(&$result){
$nstr = $estr = ”;
foreach($result as $key=>$value){
if(isset($this->treePList[$key])){
$result[$key] = $this->treePList[$key];
$inner = $this->_doNode($result[$key]);
$nstr .= $this->_parseNodeTpl($key, $inner);
}else{
$estr .= $this->_parseElementTpl($key);
}
}
return $nstr.$estr;
}
function &_parseNodeTpl($cataId, $inner){
$data = $this->treeData[$cataId];
$str = preg_replace(’ ¦__id__ ¦’, $data['id'], $this->blockTpl);
$str = preg_replace(’ ¦__name__ ¦’, $data['name'], $str);
$str = preg_replace(’ ¦__image__ ¦’, ($this->expand? $this->imgClose:$this->imgOpen), $str);
$str = preg_replace(’ ¦__open__ ¦’, ($this->expand?”:’none’), $str);
$str = preg_replace(’ ¦__inner__ ¦’, $inner, $str);
return $str;
}
function _parseElementTpl($cataId){
$data = $this->treeData[$cataId];
$str = preg_replace(’ ¦__id__ ¦’, $data['id'], $this->elementTpl);
$str = preg_replace(’ ¦__name__ ¦’, $data['name'], $str);
$str = preg_replace(’ ¦__image__ ¦’, $this->imgLine, $str);
return $str;
}

function _jsParse(){
$str = “<script language=\”javascript\”>
imgopen = \”$this->imgOpen\”;
imgclose = \”$this->imgClose\”;
</script><script src=\”$this->js\” language=\”javascript\”></script>”;
return $str;
}
/*
* 展开分类$cataId
*
*param $cataId int 要展开de分类de编号
*/
function parseCurrent($cataId){
$str = ”;
$str .= $this->_parseCurrentTpl($cataId);
while(isset($this->treeCList[$cataId]) && $this->treeCList[$cataId]!=0){
$cataId = $this->treeCList[$cataId];
$str = $this->_parseCurrentTpl($cataId).’->’.$str;
}
$this->currentStr = &$str;
}
function _parseCurrentTpl($cataId){
$data = $this->treeData[$cataId];
$str = preg_replace(’ ¦__id__ ¦’, $data['id'], $this->currentTpl);
$str = preg_replace(’ ¦__name__ ¦’, $data['name'], $str);
return $str;
}
/*
* 解析当前分类de路径
*
*param $cataId int 要解析de主分类de编号
*/
function expand($cataId){
if($this->expand>0) return ;
$str = ”;
if(isset($this->treePList[$cataId])) $str .= “expand($cataId);”;
while(isset($this->treeCList[$cataId]) && $this->treeCList[$cataId]!=0){
$str .= “expand(”.$this->treeCList[$cataId].”);”;
$cataId = $this->treeCList[$cataId];
}
$this->treeStr .= “<script language=\”javascript\”>$str</script>”;
}
/*
* 返回当前分类de路径
*/
function getCurrentStr(){

return $this->currentStr;
}
/*
* 返回分类de类树
*/
function getTreeStr(){
return $this->treeStr;
}
function setTpl($blockTpl, $elementTpl, $currentTpl, $js){
$this->blockTpl = $blockTpl;
$this->elementTpl = $elementTpl;
$this->currentTpl = $currentTpl;
$this->js = $js;
}
function setImage($open, $close, $line){
$this->imgOpen = $open;
$this->imgClose = $close;
$this->imgLine = $line;
}
function setExpend($expand){
$this->expand = $expand;
}
}
//分类de基础数据de样子如下:
$data = array(array(’id’=>1, ‘name’=>’name1′, ‘pid’=>0, ‘order’=>1),
array(’id’=>2, ‘name’=>’name2′, ‘pid’=>1, ‘order’=>1),
array(’id’=>3, ‘name’=>’name3′, ‘pid’=>0, ‘order’=>1),
array(’id’=>4, ‘name’=>’name4′, ‘pid’=>3, ‘order’=>1),
array(’id’=>5, ‘name’=>’name5′, ‘pid’=>6, ‘order’=>1),
array(’id’=>6, ‘name’=>’name6′, ‘pid’=>2, ‘order’=>1),
array(’id’=>7, ‘name’=>’name7′, ‘pid’=>6, ‘order’=>1),
array(’id’=>8, ‘name’=>’name8′, ‘pid’=>3, ‘order’=>1),
array(’id’=>9, ‘name’=>’name9′, ‘pid’=>6, ‘order’=>1),
array(’id’=>10, ‘name’=>’name10′, ‘pid’=>0, ‘order’=>1),
array(’id’=>11, ‘name’=>’name11′, ‘pid’=>10, ‘order’=>1),
array(’id’=>12, ‘name’=>’name12′, ‘pid’=>10, ‘order’=>1),
array(’id’=>13, ‘name’=>’name13′, ‘pid’=>10, ‘order’=>1),
array(’id’=>14, ‘name’=>’name14′, ‘pid’=>12, ‘order’=>1),
array(’id’=>15, ‘name’=>’name15′, ‘pid’=>12, ‘order’=>4),
);

echo “<body bgcolor=\”blue\”>”;
$tree = new Catagory($data);
echo “<hr>下面是当前分类de类树<hr>”;
//$tree->setExpend(1);
$tree->parseNode(0);
//$tree->parseNode(1);
//$tree->expand(9);
echo $tree->getTreeStr();
echo “<hr>下面是当前分类(分类de编号是9)de路径<hr>”;
$tree->parseCurrent(9);
echo $tree->getCurrentStr();

一个odbc连mssql分页的类

星期一, 06月 2nd, 2008

<!–二泉.net –>
<?
class Pages{
var $cn; //连接数据库游标
var $d; //连接数据表de游标
var $result; //结果
var $dsn; //dsn源
var $user; //用户名
var $pass; //密码
var $total; //记录总数
var $pages; //总页数
var $onepage; //每页条数
var $page; //当前页
var $fre; //上一页
var $net; //下一页
var $i; //控制每页显示
function getConnect($dsn,$user,$pass){
$this->cn=@odbc_connect($dsn,$user,$pass);
if(!$this->cn){
$error="连接数据库出错";
$this->getMess($error);
}
}
function getDo($sql){//从表中查询数据
$this->d=@odbc_do($this->cn,$sql);
if(!$this->d){
$error="查询时发生了小错误……";
$this->getMess($error);
}
return $this->d;
}
function getTotal($sql){
$this->sql=$sql;
$dT=$this->getDo($this->sql); //求总数de游标
$this->total=odbc_result($dT,’total’);//这里为何不能$this->d呢?
return $this->total;
}
function getList($sql,$onepage,$page){
$this->s=$sql;
$this->onepage=$onepage;
$this->page=$page;
$this->dList=$this->getDo($this->s); //连接表de游标
$this->pages=ceil($this->total/$this->onepage);
if($this->pages==0)
$this->pages ; //不能取到第0页
if(!isset($this->page))
$this->page=1;
$this->fre = $this->page-1; //将显示de页数
$this->nxt = $this->page 1;
$this->nums=($this->page-1)*$this->onepage;
//if($this->nums!=0){
// for($this->i=0;$this->i<$pg->getNums();odbc_fetch_row($this->dd),$this->i );//同上
//}
//$this->i=0;//为何这部分不能封装?
return $this->dList;
}
function getFanye(){
$str="";
if($this->page!=1)
$str.="<a href=".$PHP_SELF."?page=1> 首页 </a><a href=".$PHP_SELF."?page=".$this->fre."> 前页 </a>";
else
$str.="<font color=999999>首页 前页</font>";
if($this->page<$this->pages)
$str.="<a href=".$PHP_SELF."?page=".$this->nxt."> 后页 </a>";
else
$str.="<font color=999999> 后页 </font>";
if($this->page!=$this->pages)
$str.="<a href=".$PHP_SELF."?page=".$this->pages."> 尾页 </a>";
else
$str.="<font color=999999> 尾页 </font>";
$str.="共".$this->pages."页";
$str.="您正浏览第<font color=red>".$this->page."</font>页";
return $str;
}
function getNums(){
return $this->nums;
}
function getOnepage(){//每页实际条数
return $this->onepage;
}
function getI(){
return $this->i;
}
function getPage(){
return $this->page;
}
function getMess($error){//定制消息
echo"<center>$error</center>";
exit;
}
}
$pg=new Pages();
$pg->getConnect("lei","sa","star");
$pg->getTotal("select count(*) as total from xs"); //连学生表求总数
$pg->getList("select xs_name from xs order by xs_id",8,$page);
if($pg->getNums()!=0){
for($i=0;$i<$pg->getNums();odbc_fetch_row($pg->dList),$i );//同上
}
$i=0;
while(odbc_fetch_row($pg->dList)){
$name=odbc_result($pg->dList,"xs_name");
echo $name."<br>";
if($i==$pg->getOnepage()){//跳出循环
break;
}
$i ;
}
echo$pg->getFanye();
?>

分页显示Oracle数据库记录的类之二

星期一, 06月 2nd, 2008

//——————————–
// 工作函数
//——————————–
//读取记录
//主要工作函数,根据所给de条件从表中读取相应de记录
//返回值是一个二维数组,Result[记录号][字段名]
function ReadList() {
$SQL=”SELECT * FROM “.$this->Table.” “.$this->Condition.” ORDER BY “.$this->Id.” DESC”;
$stmt = OCIParse($this->LinkId,$SQL);
$bool = OCIExecute($stmt);
if (!$bool) {
echo “连接失败!”;
OCILogoff($this->LinkId);
exit;
}
else {
$ncols = OCINumCols($stmt);
for ( $i = 1; $i <= $ncols; $i )
$column_name[$i] = OCIColumnName($stmt,$i);
$k=0;
for($j=0;$j<$this->StartRec $this->Offset;$j ) OCIFetch($stmt);
for($j=0;$j<$this->MaxLine;$j ){
if(OCIFetch($stmt)){
$k ;
for($i=1;$i<=$ncols;$i )
$temp[$column_name[$i]]=OCIResult($stmt,$i);
$this->Result[]=$temp;
}
else break;
}
$this->Number=$k;
}
OCIFreeStatement($stmt);
return $this->Result;
}
//读最新de记录
//topnum指定要读出de记录数
function ReadTopList($topnum){
$SQL=”SELECT * FROM “.$this->Table.” “.$this->Condition.” ORDER BY “.$this->Id.” DESC”;
$stmt = OCIParse($this->LinkId,$SQL);
$bool = OCIExecute($stmt);
if (!$bool) {
echo “连接失败!”;
OCILogoff($this->LinkId);
exit;
}
else {
$ncols = OCINumCols($stmt);
for ( $i = 1; $i <= $ncols; $i )
$column_name[$i] = OCIColumnName($stmt,$i);
$k=0;
for($j=0;$j<$topnum;$j ){
if(OCIFetch($stmt)){
$k ;
for($i=1;$i<=$ncols;$i )
$temp[$column_name[$i]]=OCIResult($stmt,$i);
$this->TopResult[]=$temp;
}
else break;
}
$this->TopNumber=$k;
}
OCIFreeStatement($stmt);
return $this->TopResult;

}
//—————————
// 分页相关
//—————————
//显示当前页及总页数
//本函数在GetPage()后调用.
function ThePage() {
echo “第”.$this->CPages.”页/共”.$this->TPages.”页”;
}
//显示翻页按钮
//此函数要在GetPage()函数之后调用
//显示下页、上页,并加上要传递de参数
function Page() {
$k=count($this->PageQuery);
$strQuery=”"; //生成一个要传递参数字串
for($i=0;$i<$k;$i ){
$strQuery.=”&”.$this->PageQuery[$i][key].”=”.$this->PageQuery[$i][value];
}
return $strQuery;
}
function PrePage($strQuery){
$prev=$this->Offset-$this->MaxLine;
if($prev>=0)
echo “<A href=$PHP_SELF?offset=”.$prev.$strQuery.” class=newslink>上一页</A>”;
else if($this->TheFirstPage!=NULL)
echo “<A href=”.$this->TheFirstPage.” class=newslink>上一页</A>”;
else echo “上一页”;
}
function NexPage($strQuery){
$next=$this->Offset $this->MaxLine;
$k=$this->Total-$this->StartRec;
if($next<$k)
echo “<A href=$PHP_SELF?offset=”.$next.$strQuery.” class=newslink>下一页</A>”;
else
echo “下一页”;
}
//————————————
// 记录分组
//———————————-
//显示分组
function NumPage() {
$first=($this->CGroup-1)*($this->PGroup) 1;
$last=($first $this->PGroup > $this->TPages)? ($this->TPages 1):($first $this->PGroup);
$pr=($this->CGroup-2>=0)?( ($this->CGroup-2)*($this->PGroup) 1 ):(-1);
$prev=($pr!=-1)?( ($pr-1)*$this->MaxLine):(0);
$ne=($this->CGroup*$this->PGroup 1<=$this->TPages)?($this->CGroup*$this->PGroup 1):(-1);
$next=($ne!=-1)?( ($ne-1)*$this->MaxLine):(0);
$k=count($this->PageQuery);
$strQuery=”"; //生成一个要传递参数字串
for($i=0;$i<$k;$i ){
$strQuery.=”&”.$this->PageQuery[$i][key].”=”.$this->PageQuery[$i][value];
}
if($first!=1)
echo “<A href=$PHP_SELF?offset=”.$prev.$strQuery.” > << </a>”;
for($i=$first;$i<$last;$i ) {
if($this->CPages!=$i){
$current=($i-1)*$this->MaxLine;
echo “<A href=$PHP_SELF?offset=”.$current.$strQuery.” >”.$i.”</a> “;
}
else echo “<font color=#e00729>”.$i.”</font> “;
}
if($ne!=-1)
echo “<A href=$PHP_SELF?offset=”.$next.$strQuery.” > >> </a>”;
}
//******end class
}
?>

分页显示Oracle数据库记录的类之一

星期一, 06月 2nd, 2008

<?php
/*********************************************
TOracleViewPagev 2.0
日期:2000-9-23
分页显示Oracle数据库记录de类

更新日期:2000-10-19
增加显示TopRecordde功能,允许第一页显示de记录数与其它页不同.
作者:sharetop
email:ycshowtop@21cn.com
***********************************************/
class TOracleViewPage {
var $Table; //表名
var $MaxLine; //每页显示行数
var $LinkId; //数据库连接号
var $Id; //排序参考字段
var $Offset; //记录偏移量
var $Total; //记录总数
var $Number; //本页读取de记录数
var $TopNumber;//读新记录时实际取出de记录数
var $Result; //读出de结果
var $TopResult;//读新记录时de结果
var $TheFirstPage;//特殊指定第一页de链接
var $StartRec; //指定第二页de起始记录号
var $TPages; //总页数
var $CPages; //当前页数
var $TGroup;
var $PGroup; //每页显示de页号个数
var $CGroup;
var $Condition; //显示条件 如:where id=’$id’ order by id desc
var $PageQuery; //分页显示要传递de参数
//————————————-
// 以下构造函数、析构函数及初始化函数
//————————————-
//构造函数
//参数:表名、最大行数、分页参考de字段、每页显示de页号数
function TOracleViewPage($TB,$ML,$id){
global $offset;
$this->Table=$TB;
$this->MaxLine=$ML;
$this->Id=$id;
$this->StartRec=0;
if(isset($offset)) $this->Offset=$offset;
else $this->Offset=0;
$this->Condition=”";
$this->TheFirstPage=NULL;
$this->PageQury=NULL;
}
//初始化
//参数:用户名、密码、数据库
function InitDB($user,$password,$db){
if (PHP_OS == “WINNT”) $dllid=dl(”php3_oci80.dll”);
$this->LinkId = OCILogon($user,$password,$db);
}
//断开
function Destroy(){
OCILogoff($this->LinkId);
}
//————————-
// Set 函数
//————————-
//设置显示条件
//如:where id=’$id’ order by id desc
//要求是字串,符合SQL语法(本字串将加在SQL语句后)
function SetCondition($s){
$this->Condition=$s;
}
//设置每组de显示个数
function SetNumGroup($pg){
$this->PGroup=$pg;
}
//设置首页,如无则为NULL
function SetFirstPage($fn){
$this->TheFirstPage=$fn;
}
//设置起始记录,如无则取默认0
function SetStartRecord($org){
$this->StartRec=$org;
}
//设置传递参数
// key参数名 value参数值
// 如:setpagequery(”id”,$id);如有多个参数要传递,可多次调用本函数.
function SetPageQuery($key,$value){
$tmp[key]=$key; $tmp[value]=$value;
$this->PageQuery[]=$tmp;
}
//——————————–
// Get 函数
//——————————–
//取记录总数
function GetTotalRec(){
$SQL=”SELECT Count(*) AS total FROM “.$this->Table.” “.$this->Condition;
$stmt = OCIParse($this->LinkId,$SQL);
$bool = OCIExecute($stmt);
if (!$bool) {
echo “连接失败!”;
OCILogoff($this->LinkId);
exit;
}
else {
OCIFetch($stmt);
$this->Total=OCIResult($stmt,1);
}
OCIFreeStatement($stmt);
}
//取总页数、当前页
function GetPage(){
$this->TPages=ceil($this->Total/$this->MaxLine);
$this->CPages=ceil($this->Offset/$this->MaxLine) 1;
}
//取总组数、当前组
function GetGroup() {
$this->TGroup=ceil($this->TPages/$this->PGroup);
$this->CGroup=ceil($this->CPages/$this->PGroup);
}