001.
<?php
002.
classLunar {
003.
public$MIN_YEAR= 1891;
004.
public$MAX_YEAR= 2100;
005.
public$lunarInfo=array(array(0,2,9,21936),array(6,1,30,9656),array(0,2,17,9584),array(0,2,6,21168),array(5,1,26,43344),array(0,2,13,59728),array(0,2,2,27296),array(3,1,22,44368),array(0,2,10,43856),array(8,1,30,19304),array(0,2,19,19168),array(0,2,8,42352),array(5,1,29,21096),array(0,2,16,53856),array(0,2,4,55632),array(4,1,25,27304),array(0,2,13,22176),array(0,2,2,39632),array(2,1,22,19176),array(0,2,10,19168),array(6,1,30,42200),array(0,2,18,42192),array(0,2,6,53840),array(5,1,26,54568),array(0,2,14,46400),array(0,2,3,54944),array(2,1,23,38608),array(0,2,11,38320),array(7,2,1,18872),array(0,2,20,18800),array(0,2,8,42160),array(5,1,28,45656),array(0,2,16,27216),array(0,2,5,27968),array(4,1,24,44456),array(0,2,13,11104),array(0,2,2,38256),array(2,1,23,18808),array(0,2,10,18800),array(6,1,30,25776),array(0,2,17,54432),array(0,2,6,59984),array(5,1,26,27976),array(0,2,14,23248),array(0,2,4,11104),array(3,1,24,37744),array(0,2,11,37600),array(7,1,31,51560),array(0,2,19,51536),array(0,2,8,54432),array(6,1,27,55888),array(0,2,15,46416),array(0,2,5,22176),array(4,1,25,43736),array(0,2,13,9680),array(0,2,2,37584),array(2,1,22,51544),array(0,2,10,43344),array(7,1,29,46248),array(0,2,17,27808),array(0,2,6,46416),array(5,1,27,21928),array(0,2,14,19872),array(0,2,3,42416),array(3,1,24,21176),array(0,2,12,21168),array(8,1,31,43344),array(0,2,18,59728),array(0,2,8,27296),array(6,1,28,44368),array(0,2,15,43856),array(0,2,5,19296),array(4,1,25,42352),array(0,2,13,42352),array(0,2,2,21088),array(3,1,21,59696),array(0,2,9,55632),array(7,1,30,23208),array(0,2,17,22176),array(0,2,6,38608),array(5,1,27,19176),array(0,2,15,19152),array(0,2,3,42192),array(4,1,23,53864),array(0,2,11,53840),array(8,1,31,54568),array(0,2,18,46400),array(0,2,7,46752),array(6,1,28,38608),array(0,2,16,38320),array(0,2,5,18864),array(4,1,25,42168),array(0,2,13,42160),array(10,2,2,45656),array(0,2,20,27216),array(0,2,9,27968),array(6,1,29,44448),array(0,2,17,43872),array(0,2,6,38256),array(5,1,27,18808),array(0,2,15,18800),array(0,2,4,25776),array(3,1,23,27216),array(0,2,10,59984),array(8,1,31,27432),array(0,2,19,23232),array(0,2,7,43872),array(5,1,28,37736),array(0,2,16,37600),array(0,2,5,51552),array(4,1,24,54440),array(0,2,12,54432),array(0,2,1,55888),array(2,1,22,23208),array(0,2,9,22176),array(7,1,29,43736),array(0,2,18,9680),array(0,2,7,37584),array(5,1,26,51544),array(0,2,14,43344),array(0,2,3,46240),array(4,1,23,46416),array(0,2,10,44368),array(9,1,31,21928),array(0,2,19,19360),array(0,2,8,42416),array(6,1,28,21176),array(0,2,16,21168),array(0,2,5,43312),array(4,1,25,29864),array(0,2,12,27296),array(0,2,1,44368),array(2,1,22,19880),array(0,2,10,19296),array(6,1,29,42352),array(0,2,17,42208),array(0,2,6,53856),array(5,1,26,59696),array(0,2,13,54576),array(0,2,3,23200),array(3,1,23,27472),array(0,2,11,38608),array(11,1,31,19176),array(0,2,19,19152),array(0,2,8,42192),array(6,1,28,53848),array(0,2,15,53840),array(0,2,4,54560),array(5,1,24,55968),array(0,2,12,46496),array(0,2,1,22224),array(2,1,22,19160),array(0,2,10,18864),array(7,1,30,42168),array(0,2,17,42160),array(0,2,6,43600),array(5,1,26,46376),array(0,2,14,27936),array(0,2,2,44448),array(3,1,23,21936),array(0,2,11,37744),array(8,2,1,18808),array(0,2,19,18800),array(0,2,8,25776),array(6,1,28,27216),array(0,2,15,59984),array(0,2,4,27424),array(4,1,24,43872),array(0,2,12,43744),array(0,2,2,37600),array(3,1,21,51568),array(0,2,9,51552),array(7,1,29,54440),array(0,2,17,54432),array(0,2,5,55888),array(5,1,26,23208),array(0,2,14,22176),array(0,2,3,42704),array(4,1,23,21224),array(0,2,11,21200),array(8,1,31,43352),array(0,2,19,43344),array(0,2,7,46240),array(6,1,27,46416),array(0,2,15,44368),array(0,2,5,21920),array(4,1,24,42448),array(0,2,12,42416),array(0,2,2,21168),array(3,1,22,43320),array(0,2,9,26928),array(7,1,29,29336),array(0,2,17,27296),array(0,2,6,44368),array(5,1,26,19880),array(0,2,14,19296),array(0,2,3,42352),array(4,1,24,21104),array(0,2,10,53856),array(8,1,30,59696),array(0,2,18,54560),array(0,2,7,55968),array(6,1,27,27472),array(0,2,15,22224),array(0,2,5,19168),array(4,1,25,42216),array(0,2,12,42192),array(0,2,1,53584),array(2,1,21,55592),array(0,2,9,54560));
006.
007.
/**
008.
* 將陽曆轉換爲陰曆
009.
* @param year 公曆-年
010.
* @param month 公曆-月
011.
* @param date 公曆-日
012.
*/
013.
functionconvertSolarToLunar($year,$month,$date){
014.
//debugger;
015.
$yearData=$this->lunarInfo[$year-$this->MIN_YEAR];
016.
if($year==$this->MIN_YEAR&&$month<=2&&$date<=9){
017.
returnarray(1891,'正月','初一','辛卯',1,1,'兔');
018.
}
019.
return$this->getLunarByBetween($year,$this->getDaysBetweenSolar($year,$month,$date,$yearData[1],$yearData[2]));
020.
}
021.
022.
/**
023.
* 將陰曆轉換爲陽曆
024.
* @param year 陰曆-年
025.
* @param month 陰曆-月,閏月處理:例如若是當年閏五月,那麼第二個五月就傳六月,至關於陰曆有13個月,只是有的時候第13個月的天數爲0
026.
* @param date 陰曆-日
027.
*/
028.
functionconvertLunarToSolar($year,$month,$date){
029.
$yearData=$this->lunarInfo[$year-$this->MIN_YEAR];
030.
$between=$this->getDaysBetweenLunar($year,$month,$date);
031.
$res=mktime(0,0,0,$yearData[1],$yearData[2],$year);
032.
033.
$res=date('Y-m-d',$res+$between*24*60*60);
034.
035.
$day = split_date($res);
036.
$year =$day[0];
037.
$month=$day[1];
038.
$day =$day[2];
039.
040.
returnarray($year,$month,$day);
041.
}
042.
043.
/**
044.
* 判斷是不是閏年
045.
* @param year
046.
*/
047.
functionisLeapYear($year){
048.
return(($year%4==0 &&$year%100 !=0) || ($year%400==0));
049.
}
050.
051.
/**
052.
* 獲取干支紀年
053.
* @param year
054.
*/
055.
functiongetLunarYearName($year){
056.
$sky=array('庚','辛','壬','癸','甲','乙','丙','丁','戊','己');
057.
$earth=array('申','酉','戌','亥','子','醜','寅','卯','辰','巳','午','未');
058.
059.
$year=$year.'';
060.
return$sky[$year{3}].$earth[$year%12];
061.
}
062.
063.
/**
064.
* 根據陰曆年獲取生肖
065.
* @param year 陰曆年
066.
*/
067.
functiongetYearZodiac($year){
068.
$zodiac=array('猴','雞','狗','豬','鼠','牛','虎','兔','龍','蛇','馬','羊');
069.
return$zodiac[$year%12];
070.
}
071.
072.
/**
073.
* 獲取陽曆月份的天數
074.
* @param year 陽曆-年
075.
* @param month 陽曆-月
076.
*/
077.
functiongetSolarMonthDays($year,$month){
078.
$monthHash=array('1'=>31,'2'=>$this->isLeapYear($year)?29:28,'3'=>31,'4'=>30,'5'=>31,'6'=>30,'7'=>31,'8'=>31,'9'=>30,'10'=>31,'11'=>30,'12'=>31);
079.
return$monthHash["$month"];
080.
}
081.
082.
083.
/**
084.
* 獲取陰曆月份的天數
085.
* @param year 陰曆-年
086.
* @param month 陰曆-月,從一月開始
087.
*/
088.
functiongetLunarMonthDays($year,$month){
089.
$monthData=$this->getLunarMonths($year);
090.
return$monthData[$month-1];
091.
}
092.
093.
/**
094.
* 獲取陰曆每個月的天數的數組
095.
* @param year
096.
*/
097.
functiongetLunarMonths($year){
098.
099.
$yearData=$this->lunarInfo[$year-$this->MIN_YEAR];
100.
$leapMonth=$yearData[0];
101.
102.
$bit=decbin($yearData[3]);
103.
for($i= 0;$i<strlen($bit);$i++) {
104.
$bitArray[$i] =substr($bit,$i, 1);
105.
}
106.
107.
for($k=0,$klen=16-count($bitArray);$k<$klen;$k++){
108.
array_unshift($bitArray,'0');
109.
}
110.
111.
$bitArray=array_slice($bitArray,0,($leapMonth==0?12:13));
112.
for($i=0;$i<count($bitArray);$i++){
113.
$bitArray[$i] =$bitArray[$i] + 29;
114.
}
115.
116.
return$bitArray;
117.
}
118.
119.
/**
120.
* 獲取農曆每一年的天數
121.
* @param year 農曆年份
122.
*/
123.
functiongetLunarYearDays($year){
124.
$yearData=$this->lunarInfo[$year-$this->MIN_YEAR];
125.
$monthArray=$this->getLunarYearMonths($year);
126.
$len=count($monthArray);
127.
return($monthArray[$len-1]==0?$monthArray[$len-2]:$monthArray[$len-1]);
128.
}
129.
130.
functiongetLunarYearMonths($year){
131.
//debugger;
132.
$monthData=$this->getLunarMonths($year);
133.
$res=array();
134.
$temp=0;
135.
$yearData=$this->lunarInfo[$year-$this->MIN_YEAR];
136.
$len= ($yearData[0]==0?12:13);
137.
for($i=0;$i<$len;$i++){
138.
$temp=0;
139.
for($j=0;$j<=$i;$j++){
140.
$temp+=$monthData[$j];
141.
}
142.
array_push($res,$temp);
143.
}
144.
return$res;
145.
}
146.
147.
/**
148.
* 獲取閏月
149.
* @param year 陰曆年份
150.
*/
151.
functiongetLeapMonth($year){
152.
$yearData=$this->lunarInfo[$year-$this->MIN_YEAR];
153.
return$yearData[0];
154.
}
155.
156.
/**
157.
* 計算陰曆日期與正月初一相隔的天數
158.
* @param year
159.
* @param month
160.
* @param date
161.
*/
162.
functiongetDaysBetweenLunar($year,$month,$date){
163.
$yearMonth=$this->getLunarMonths($year);
164.
165.
$res=0;
166.
for($i=1;$i<$month;$i++){
167.
$res+=$yearMonth[$i-1];
168.
}
169.
$res+=$date-1;
170.
171.
return$res;
172.
}
173.
174.
/**
175.
* 計算2個陽曆日期之間的天數
176.
* @param year 陽曆年
177.
* @param cmonth
178.
* @param cdate
179.
* @param dmonth 陰曆正月對應的陽曆月份
180.
* @param ddate 陰曆初一對應的陽曆天數
181.
*/
182.
functiongetDaysBetweenSolar($year,$cmonth,$cdate,$dmonth,$ddate){
183.
184.
$a=mktime(0,0,0,$cmonth,$cdate,$year);
185.
$b=mktime(0,0,0,$dmonth,$ddate,$year);
186.
187.
returnceil(($a-$b)/24/3600);
188.
}
189.
190.
/**
191.
* 根據距離正月初一的天數計算陰曆日期
192.
* @param year 陽曆年
193.
* @param between 天數
194.
*/
195.
functiongetLunarByBetween($year,$between){
196.
//debugger;
197.
$lunarArray=array();
198.
$yearMonth=array();
199.
$t=0;
200.
$e=0;
201.
$leapMonth=0;
202.
$m='';
203.
204.
if($between==0){
205.
array_push($lunarArray,$year,'正月','初一');
206.
$t= 1;
207.
$e= 1;
208.
}else{
209.
$year=$between>0?$year: ($year-1);
210.
$yearMonth=$this->getLunarYearMonths($year);
211.
$leapMonth=$this->getLeapMonth($year);
212.
$between=$between>0?$between: ($this->getLunarYearDays($year)+$between);
213.
214.
for($i=0;$i<13;$i++){
215.
if($between==$yearMonth[$i]){
216.
$t=$i+2;
217.
$e=1;
218.
break;
219.
}elseif($between<$yearMonth[$i]){
220.
$t=$i+1;
221.
$e=$between-(emptyempty($yearMonth[$i-1])?0:$yearMonth[$i-1])+1;
222.
break;
223.
}
224.
}
225.
$m= ($leapMonth!=0&&$t==$leapMonth+1)?('閏'.$this->getCapitalNum($t- 1,true)):$this->getCapitalNum(($leapMonth!=0&&$leapMonth+1<$t?($t-1):$t),true);
226.
227.
array_push($lunarArray,$year,$m,$this->getCapitalNum($e,false));
228.
}
229.
array_push($lunarArray,$this->getLunarYearName($year));//天干地支
230.
array_push($lunarArray,$t,$e);
231.
array_push($lunarArray,$this->getYearZodiac($year));//12生肖
232.
array_push($lunarArray,$leapMonth);//閏幾月
233.
return$lunarArray;
234.
}
235.
236.
/**
237.
* 獲取數字的陰曆叫法
238.
* @param num 數字
239.
* @param isMonth 是不是月份的數字
240.
*/
241.
functiongetCapitalNum($num,$isMonth){
242.
$isMonth=$isMonth|| false;
243.
$dateHash=array('0'=>'','1'=>'一','2'=>'二','3'=>'三','4'=>'四','5'=>'五','6'=>'六','7'=>'七','8'=>'八','9'=>'九','10'=>'十 ');
244.
$monthHash=array('0'=>'','1'=>'正月','2'=>'二月','3'=>'三月','4'=>'四月','5'=>'五月','6'=>'六月','7'=>'七月','8'=>'八月','9'=>'九月','10'=>'十月','11'=>'冬月','12'=>'臘月');
245.
$res='';
246.
247.
if($isMonth){
248.
$res=$monthHash[$num];
249.
}else{
250.
if($num<=10){
251.
$res='初'.$dateHash[$num];
252.
}elseif($num>10&&$num<20){
253.
$res='十'.$dateHash[$num-10];
254.
}elseif($num==20){
255.
$res="二十";
256.
}elseif($num>20&&$num<30){
257.
$res="廿".$dateHash[$num-20];
258.
}elseif($num==30){
259.
$res="三十";
260.
}
261.
}
262.
return$res;
263.
}
264.
265.
}
266.
?>
267.
<?php
268.
header('Access-Control-Allow-Origin: *');
269.
header("Content-Type:text/javascript;charset=utf-8");
270.
$lunar=newLunar();
271.
$year=date("Y");
272.
$month=date("n");
273.
$day=date("j");
274.
$ldate=$lunar->convertSolarToLunar($year,$month,$day);
275.
echo('lunar({"year":"'.$ldate[0].'","month":"'.$ldate[1].'","day":"'.$ldate[2].'","zodiac":"'.$ldate[6].'","sign":"'.$ldate[3].'"})');
276.
?>