月度归档:2016年11月

SVN 一些客户端命令选项

全局选项:

--username ARG

  指定用户名称 ARG

--password ARG

  指定密码 ARG

--no-auth-cache

  不要缓存用户认证令牌

--non-interactive

  不要交互提示

--trust-server-cert

  不提示的接受未知的证书颁发机构发行的 SSL 服务器证书(只用于选项“--non-interactive”)

--config-dir ARG

  从目录 ARG 读取用户配置文件

--config-option ARG

  以下属格式设置用户配置选项:

    FILE:SECTION:OPTION=[VALUE]

  例如:

    servers:global:http-library=serf

svn
add

  把文件以及目录的名称添加到版本控制系统。他们会在下次提交时被添加到项目仓库中去。

  svn
add path...

选项:

--auto-props

  再添加它们的时候自动设置文件的属性。

--no-auto-props

  禁用自动设置属性。

svn
blame (ann, annotate, praise)

  显示文件每行的版本以及作者信息。

  svn
blame target...

选项:

--revision,
-r rev

  如果指定的rev是单个版本,显示该版本的作者信息。如果指定的版本范围rev1:rev2,显示rev2版本的作者信息,但是只检查版本到rev1(要使得这命令有意义,rev1必须小于rev2)。

svn
cat

  输出指定文件或者URL的内容。

  svn
cat target...

选项:

--revision,
-r rev

  输出版本revtarget的内容。

svn
checkout (co)

  从项目仓库签出一个工作拷贝。

  svn
checkout url... path

  签出给定URL。如果没有指定path参数,签出的本地目录名使用URL的基础名称(base
name
)。如果指定了path,而且URL参数只有一个,签出到该目录。如果指定了path,但是有多个,签出到path目录之下的子目录中,目录名使用对应URL的基础名称。

选项:

--revision,
-r rev

  指定要签出的版本

svn
cleanup

  清理工作拷贝,移除锁,完成未完成的操作,等等。

  svn
cleanup path...

svn
commit (ci)

  把改动从你的工作拷贝发送到项目仓库。

  svn
commit path...

选项:

--message,
-m msg

  使用msg作为提交日志消息。

--file,
-F file

  使用file的内容作为提交日志的消息。

--no-unlock

  不要在提交的时候释放锁。

svn
copy (cp)

  在工作拷贝或者项目仓库中制造包括历史在内的复本。

  svn
copy src... dest

  当复制多个源时,它们作为dest的子节点增加,
dest
必须是目录。srcdest可以是工作副本路径(WC)或版本库地址(URL):

src dest 效果
WC WC 拷贝并添加(包括历史)
WC URL 立即提交WC的拷贝到URL
URL WC 签出URLWC,添加
URL URL 完全服务器端拷贝,用于制作分支和标签等

选项:

--revision,
-r rev

  指定要拷贝的src的版本。只在src是版本库地址URL时才有意义。

svn
delete (del, remove, rm)

  从版本控制系统中移除文件或者目录。

  svn
delete target...

  从项目仓库删除文件或者目录。如果target是工作拷贝中的文件或者目录,它被工作拷贝中移除并且在下次提交时删除掉。如果target是项目仓库URL,则会通过一次立即的提交从项目仓库中删除。

选项:

--message,
-m msg

  使用msg作为提交日志信息。

--file,
-F file

  使用file的内容作为提交日志信息。

svn
diff (di)

  显示两个路径之间的差异。

  1.
svn diff -r rev1:rev2 target...

  2.
svn diff oldurl newurl

  在第一种格式中,显示target在两个版本rev1rev2之间的改动。target可以是工作拷贝路径或者URL

  在第二种格式中,显示最新版本的oldurlnewurl之间的差异。

选项:

--old
arg

  使用arg作为老一些的目标

--new
arg

  使用arg作为新一些的目标

svn
export

  创建目录树的一个无版本记录的拷贝。

  svn
export URL path

  从项目仓库的指定URL到处一个干净的目录树到path中,如果指定了rev参数,到处rev版本,否则到处最新版本。如果path被省略了,URL的基本名称将被作为本地目录的名称。

选项:

--revision,
-r rev

  指定到处项目仓库的版本。

--native-eol
style

  对于有本地svn:eol-style属性的文件,使用不同的行结尾标识符而不是系统标准的文件行结尾标识符。style必须是LFCR或者CRLF之中的一个。

svn
import

  提交一个无版本的文件或者目录到项目仓库中。

  svn
import path URL

  递归提交path的一个拷贝到URL。如果path被省略了,将默认提交当前目录。父目录会根据需要在项目仓库中创建。

选项:

--auto-props

  在导入过程中自动设置属性给文件。

--no-auto-props

  对于导入的文件禁用自动设置属性。

svn
info

  显示文件或者目录的信息。

  svn
info path...

  打印每个path的信息。

选项:

--recursive,
-r

  递归显示目录的信息

svn
list (ls)

  列出项目仓库中的目录条目。

  svn
list target...

  如果是在项目仓库中,列出每个target文件以及每个target目录的内容。如果target是在工作拷贝中,会使用对应的项目仓库URL

选项:

--verbose,
-v

  显示额外信息。

svn
lock

  锁住文件让其他用户不能提交改动。

  svn
lock target

  与项目仓库服务器联系,获得对一个或者多个工作拷贝文件的锁。一旦锁住了,其他用户就不能提交改动该文件,除非锁被释放或者被破坏。

选项:

--message,
-m msg

  使用msg作为锁消息信息。

--force

  强制从其他用户或者工作拷贝获得锁。

svn
log

  显示一些版本或者文件的日志信息。

  svn
log target

  打印本地路径或者项目仓库URL的日志信息。对于每个本地路径,默认的版本范围是BASE:1,对于URL默认的版本范围是HEAD:1

选项:

--revision,
-r rev

  如果rev是单个版本,只显示该版本的日志条目。如果rev是版本范围,显示这些版本的日志条目,

--verbose,
-v

  打印每条日志消息所影响的路径。

--stop-on-copy

  在遍历历史的时候不要穿越拷贝(对于查找分支的起点很有用)。

svn
merge

  把两个来源的差异应用给工作拷贝路径。

  1.
svn merge sourceURL1@rev1 sourceURL2@rev2 WCPath

  2.
svn merge sourceWCPath1@rev1 sourceWCPath2@rev2 WCPath

  3.
svn merge -r rev1:rev2 SOURCE WCPath

  第一个格式中,源URL被指定了版本rev1rev2.这是两个要被比较的源。如果没有指明版本,默认使用最新版本。

  在第二个格式中,对应工作拷贝的URL被指定作为要比较源。版本号必须指定。

  在第三种格式中,SOURCE可以是URL或者工作拷贝中条目,使用工作拷贝的话会使用对应的URL代替。这个URL会被比较它的rev1rev2版本。

  WCPath是接受这些改动的工作拷贝路径。如果WCPath被省略,假定就是当前目录,除非来源尤一个唯一的base
name
匹配了当前目录的文件,如果是这样的话改动就会应用于那个文件。

选项:

--diff3-cmd
cmd

  使用cmd作为合并命令。

--ignore-ancestry

  在计算合并时忽略过去历史。

svn
mkdir

  创建版本控制下的新目录。

  1.
svn mkdir PATH...

  2.
svn mkdir URL...

  在第一种情况下,每个以工作副本PATH指定的目录,都会在本地创建,并且加入增加调度,直到下次提交。

  在第二种情况中,每个以URL指定的目录,都会通过立即提交在版本库中创建。

  在这两种情况下,所有的中间目录都必须事先存在,除非使用--parents选项。

svn
move (mv, rename, ren)

  移动或者重命名工作拷贝或者项目仓库中的文件或者目录。

  svn
move src... dest

  当移动多个源时,它们作为dest的子节点添加,dest必须是目录。本命令等同于先“copy”,然后“delete”srcdest可以是工作拷贝路径或者项目仓库URL。在工作拷贝中,移动被执行并且新的位置于下次提交时添加。对于项目仓库URL,一个完全服务器端的重名名操作被立即执行。

选项:

--revision,
-r rev

  使用版本rev作为源来执行这次移动。

svn
propdel (pdel, pd)

  删除文件或者目录的属性。

  svn
propdel propname path...

  在本地工作拷贝中删除pathpropname属性

svn
propedit (pedit, pe)

  编辑文件或者目录的属性。

  svn
propedit propname path..

  打开一个外部的编辑器在本地工作拷贝中编辑pathpropname属性。

svn
propget (pget, pg)

  打印文件或者目录的属性。

  svn
propget propname path...

  打印每个pathpropname的内容。本子命令默认会在属性内容加上额外的换行符,得到美观的输出。另外,当同时处理多个路径时,每一个属性内容会在开头增加上它所对应的路径。

选项:

--strict

  禁用额外的换行和其他的美化措施。

svn
proplist (plist, pl)

  列出文件或者路径的所有属性。

  svn
proplist path...

  列出path的所有属性。

选项:

--verbose,
-v

  打印额外的信息。

--recursive,
-R

  递归下降。

--revision,
-r rev

  列出path在版本rev定义的属性。

svn
propset (pset, ps)

  设置文件或者路径的属性。

  svn
propset propname propval path...

  对于path,设置值propvalpropname属性。如果propval没有指定,你必须使用-F选项来指定一个文件,其内容会作为属性的值设置给属性。

选项:

--file,
-F file

  读取file的内容,使用它作为属性值。

--recursive,
-R

  递归下降。

--encoding
enc

  把值作为使用enc编码的字符集。

svn
resolve

  解决工作副本中目录或文件的冲突。

  resolve
--accept=ARG [path...]

  注意:当前需要选项—accept

选项:

--targets
ARG

  传递文件ARG内容为附件参数

--recursive,
-R

  递归下降

--accept
ARG

  指定自动解决冲突动作的源(base,
working, mine-conflict, theirs-conflict, mine-full, theirs-full

svn
resolved

  移除工作拷贝文件或者目录的冲突状态。

  svn
resolved path...

  标记之前包含冲突的文件为“已解决”。注意这个命令不会从语意上解决冲突或者移除冲突标记;它只是移除冲突相关的文件并且允许path被再次提交。它已经过时,被
svn
resolve --accept working”
取代。

选项:

--recursive,
-R

  递归下降。

svn
revert

  恢复工作拷贝中的文件(撤销最新的本地修改)。

  svn
revert path...

  这个命令不许要网络连接并且撤销你对path所做的一切改动。它不恢复被删除的目录。它会它解除任何冲突的状态。

选项:

--recursive,
-R

  递归下降

svn
status (stat, st)

  打印工作拷贝中文件和目录的状态。

  svn
status path...

  没有任何参数,只是打印本地修改过得条目(无须访问网络)。

  加-u参数,添加工作版本和服务器过期信息。

  加-v参数,打印每个条目完整的版本信息。

  输出中的前七列的宽度均为一个字符。

  第一列:指出条目是被添加、删除还是修改过了

    “
无修改

    A 增加

    C 冲突

    D 删除

    I 忽略

    M 改变

    R 替换

    X 未纳入版本控制的目录,被外部引用的目录所创建

    ? 未纳入版本控制

    ! 该项目已遗失(被非svn命令删除)或不完整

    ~ 版本控制下的项目与其它类型的项目重名

  第二列:显示目录或文件的属性状态

    “
无修改

    C 冲突

    M 改变

  第三列:工作拷贝目录是否被锁定

    “
未锁定

    L 锁定

  第四列:已调度的提交是否包含副本历史

    “
没有历史

    + 包含历史

  第五列:该条目相对其父目录是否已切换,或者是外部引用的文件

    “
正常

    S 已切换

    X 被外部引用创建的文件

  第六列:版本库锁定标记

    (没有-u

    “
没有锁定标记

    K 存在锁定标记

    (使用-u

    “
没有在版本库中锁定,没有锁定标记

    K 在版本库中被锁定,存在锁定标记

    O 在版本库中被锁定,锁定标记在一些其他工作副本中

    T 在版本库中被锁定,存在锁定标记但已被窃取

    B 没有在版本库中被锁定,存在锁定标记但已被破坏

  第七列:项目冲突标记

    “
正常

    C 树冲突

    如果项目包含于树冲突之中,在项目状态行后会附加行,说明冲突的种类。

  是否过期的信息出现的位置是第九栏(-u并用时)

    “
工作拷贝是最新版的

    * 服务器上有更新版本

  剩余的栏位皆为变动宽度,并以空白隔开:

    工作版本号(使用-u-v时;被复制时显示“-”)

    最后提交的版本与最后提交的作者(使用-v)

    工作副本路径总是最后一栏,所以它可以包含空白字符。

选项:

--show-update,
-u

  联系服务器显示更新信息。

--verbose,
-v

  打印额外的信息

--non-recursive,
-N

  只操作单个目录

--no-ignore

  忽视默认设置和svn:ignore属性设置的忽略项

svn
switch (sw)

  把工作拷贝转向其他URL

  svn
switch URL path

  更新工作拷贝让其使用项目仓库的新URL。这个行为类似svn
update
,而且是一种把工作拷贝转向到同一项目仓库中的分支或者标签的办法。

选项:

--revision,
-r rev

  转向到版本rev

--non-recursive,
-N

  只操作单个目录

--diff3-cmd
cmd

  使用cmd作为合并命令

svn
unlock

  解开工作拷贝文件或者项目仓库URL的锁。

  svn
unlock target...

  释放当前对target的锁,以让其他用户可以提交改动。

选项:

--force

  破坏现有对targe的锁,甚至它不是被当前工作拷贝所拥有的。

svn
update (up)

  把改动从项目版本库带到工作拷贝来。

  svn
update path...

  如果没有指定版本,把工作拷贝更新为新最新版本。否则把宫组拷贝同步为-r选项指定的版本。

  对于每个更新过的条目会有单独一行,开头有一个字符表示做过的动作。这些字符有一下含义:

  A 添加

  D 删除

  U 更新

  C 冲突

  M 合并

  第一列的字符表示了对实际文件的更新,对于文件属性的更新被列到第二列。

选项:

--revision,
-r rev

  更新到版本rev

--non-recrusive,
-N

  只操作单个目录

--diff3-cmd
cmd

  使用cmd作为合并命令

IP - A、B、C、D、E - 网段 - 网络

IP地址分为A,B,C,D,E五类。

网络号:用于识别主机所在的网络;

主机号:用于识别该网络中的主机。

其中A类分配给政府机关使用,B类地址给大中型企业使用,C类地址给个人使用。这三种是主要的。

IP地址分为五类,A类保留给政府机构,B类分配给中等规模的公司,C类分配给任何需要的人,D类用于组播,E类用于实验,各类可容纳的地址数目不同。

其中A类、B类、和C类这三类地址用于TCP/IP节点,其它两类D类和E类被用于特殊用途。

A、B、C三类IP地址的特征:当将IP地址写成二进制形式时,

A类:0打头

B类:10打头
C类:110打头
D类:1110打头
E类:11110打头
A、B、C、D、E三类IP地址的特征:当将IP地址写成十进制形式时:
A类:1.0.0.1—126.155.255.254
B类:128.0.0.1—191.255.255.254
C类:192.0.0.1—223.255.255.254
D类:224.0.0.1—239.255.255.254
E类:240.0.0.1—255.255.255.254

 

1. A类地址
⑴ A类地址第1字节为网络地址,其它3个字节为主机地址。
⑵ A类地址范围:1.0.0.1—126.155.255.254
⑶ A类地址中的私有地址和保留地址:
10.X.X.X是私有地址(所谓的私有地址就是在互联网上不使用,而被用在局域网络中的地址)。
127.X.X.X是保留地址,用做循环测试用的。

2. B类地址
⑴ B类地址第1字节和第2字节为网络地址,其它2个字节为主机地址。
⑵ B类地址范围:128.0.0.1—191.255.255.254
⑶ B类地址的私有地址和保留地址
172.16.0.0—172.31.255.255是私有地址
169.254.X.X是保留地址。如果IP地址是自动获取IP地址,而网络上又没有找到可用的DHCP服务器。就会得到其中一个IP。

3. C类地址
⑴ C类地址第1字节、第2字节和第3个字节为网络地址,第4个个字节为主机地址。另外第1个字节的前三位固定为110。
⑵ C类地址范围:192.0.0.1—223.255.255.254
⑶ C类地址中的私有地址:
192.168.X.X是私有地址。

4. D类地址
⑴ D类地址不分网络地址和主机地址,它的第1个字节的前四位固定为1110。
⑵ D类地址范围:224.0.0.1—239.255.255.254

5. E类地址
⑴ E类地址也不分网络地址和主机地址,它的第1个字节的前五位固定为11110。
⑵ E类地址范围:240.0.0.1—255.255.255.254

其它:

地址格式为:IP地址=网络地址+主机地址 或 IP地址=网络地址+子网地址+主机地址。

网络地址是由ICANN(the Internet Corporation for Assigned Names and Numbers)分配,下级有负责
北美地区的InterNIC
负责欧洲地区的RIPENIC
负责亚太地区的APNIC
目的是为了保证网络地址的全球唯一性。主机地址是由各个网络的系统管理员分配。因此,网络地址的唯一性与网络内主机地址的唯一性确保了IP地址的全球唯一性。

点击查看原图

 

Remarks:
192.168.0.0 - 192.168.255.255 (192.168/16 prefix)    / 256*256-2 = 65534
172.16.0.0 - 172.31.255.255 (172.16/12 prefix)    / 16*256*256-2 = 1048574
10.0.0.0 - 10.255.255.255 (10/8 prefix)    / 256*256*256-2 = 16777214

links:
http://tool.520101.com/wangluo/ipjisuan/
https://tools.ietf.org/html/rfc4632

notation       addrs/block      # blocks
--------       -----------     ----------
n.n.n.n/32               1     4294967296    "host route"
n.n.n.x/31               2     2147483648    "p2p link"
n.n.n.x/30               4     1073741824
n.n.n.x/29               8      536870912
n.n.n.x/28              16      268435456
n.n.n.x/27              32      134217728
n.n.n.x/26              64       67108864
n.n.n.x/25             128       33554432
n.n.n.0/24             256       16777216    legacy "Class C"
n.n.x.0/23             512        8388608
n.n.x.0/22            1024        4194304
n.n.x.0/21            2048        2097152
n.n.x.0/20            4096        1048576
n.n.x.0/19            8192         524288
n.n.x.0/18           16384         262144
n.n.x.0/17           32768         131072
n.n.0.0/16           65536          65536    legacy "Class B"
n.x.0.0/15          131072          32768
n.x.0.0/14          262144          16384
n.x.0.0/13          524288           8192
n.x.0.0/12         1048576           4096
n.x.0.0/11         2097152           2048
n.x.0.0/10         4194304           1024
n.x.0.0/9          8388608            512
n.0.0.0/8         16777216            256    legacy "Class A"
x.0.0.0/7         33554432            128
x.0.0.0/6         67108864             64
x.0.0.0/5        134217728             32
x.0.0.0/4        268435456             16
x.0.0.0/3        536870912              8
x.0.0.0/2       1073741824              4
x.0.0.0/1       2147483648              2
0.0.0.0/0       4294967296              1    "default route"

RFC1918:
The Internet Assigned Numbers Authority (IANA) has reserved the following three blocks of the IP address space for private internets:
10.0.0.0 - 10.255.255.255 (10/8 prefix)
172.16.0.0 - 172.31.255.255 (172.16/12 prefix)
192.168.0.0 - 192.168.255.255 (192.168/16 prefix)

RFC文档:
RFC4291: IP Version 6 Addressing Architecture
RFC2606: Reserved Top Level DNS Names
RFC6761: Special-Use Domain Names
RFC5735: Special Use IPv4 Addresses

#################################################

Private IP Address Ranges

Address ranges below are reserved by IANA for private intranets, and not routable to the Internet.
For additional information, see RFC 1918.

10.0.0.0 ~ 10.255.255.255 (10.0.0.0/8 prefix)
172.16.0.0 ~ 172.31.255.255 (172.16.0.0/12 prefix)
192.168.0.0 ~ 192.168.255.255 (192.168.0.0/16 prefix)

Reserved and special use addresses:

0.0.0.0/8 - Current network (only valid as source address) RFC 1700
127.0.0.0 is reserved for loopback and IPC on the localhost.
127.0.0.1 ~ 127.255.255.254 (127.0.0.0/8) - loopback IP addresses (refers to self) RFC 5735
192.0.0.0/24 - reserved (IANA) RFC 5735
192.88.99.0/24 - IPv6 to IPv4 relay. RFC 3068
198.18.0.0/15 - network benchmark tests. RFC 2544
198.51.100.0/24 - TEST-NET-2. RFC 5737
203.0.113.0/24 - TEST-NET-3. RFC 5737
224.0.0.0 ~ 239.255.255.255 (224.0.0.0/4) reserved for multicast addresses. RFC 3171
240.0.0.0/4 - reserved (former Class E network) RFC 1700
255.255.255.255 is the limited broadcast address (limited to all other nodes on the LAN) RFC 919

255 in any part of the IP is reserved for broadcast addressing
0.0.0.0 in routing context means the default route (to "the rest of" the internet) RFC 1700
0.0.0.0 in the context of firewalls means "all addresses of the local machine" RFC 1700

 

 

 

C# UDP组播

//组播代码

using System;

using System.Collections.Generic;

using System.Linq;using System.Text;

using System.Net;using System.Net.Sockets;

using System.Threading;

namespace Test {

    class Program     {
        static void Main(string[] args)
        {
            UdpClient client = new UdpClient(5566);
            client.JoinMulticastGroup(IPAddress.Parse("234.5.6.7"));
            IPEndPoint multicast = new IPEndPoint(IPAddress.Parse("234.5.6.7"), 7788);
            byte[] buf = Encoding.Default.GetBytes("Hello from multicast");
            Thread t = new Thread(new ThreadStart(RecvThread));
            t.IsBackground = true;
            t.Start();
            while (true)
            {
                client.Send(buf, buf.Length, multicast);
                Thread.Sleep(1000);
            }
        }

        static void RecvThread()
        {
            UdpClient client = new UdpClient(7788);
            client.JoinMulticastGroup(IPAddress.Parse("234.5.6.7"));
            IPEndPoint multicast = new IPEndPoint(IPAddress.Parse("234.5.6.7"), 5566);
            while (true)
            {
                byte[] buf = client.Receive(ref multicast);
                string msg = Encoding.Default.GetString(buf);
                Console.WriteLine(msg);
            }
        }
    }
}

组播地址为 224.0.0.0 ~ 239.255.255.255,其中 224.0.0.0~224.255.255.255 不建议在用户程序中使用,因为它们一般都有特殊用途。

 

//广播代码

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Net;
using System.Net.Sockets;
using System.Threading;
namespace ConsoleApplication1
{
    class Program
    {
        static void Main(string[] args)
        {
           
Socket socket = new Socket(AddressFamily.InterNetwork,
SocketType.Dgram, ProtocolType.IP);//只能用 P协议发送广播,所以ProtocolType设置为 P

            IPEndPoint iep = new IPEndPoint(IPAddress.Broadcast, 10881);                              //让其自动提供子网中的IP地址
           
socket.SetSocketOption(SocketOptionLevel.Socket,
SocketOptionName.Broadcast, 1);          //设置broadcast值为1,允许套接字发送广播信息

            Int32  i = 0;
            while (true)
            {
                Thread.Sleep(1000);
                string info = "Hello";
                byte[] bInfo = Encoding.UTF8.GetBytes(info);
                socket.SendTo(bInfo, iep);
            }
        }
    }

}



php date

a - "am" 或是 "pm" 
A - "AM" 或是 "PM" 
d - 几日,二位数字,若不足二位则前面补零; 如: "01" 至 "31" 
D - 星期几,三个英文字母; 如: "Fri" 
F - 月份,英文全名; 如: "January" 
h - 12 小时制的小时; 如: "01" 至 "12" 
H - 24 小时制的小时; 如: "00" 至 "23" 
g - 12 小时制的小时,不足二位不补零; 如: "1" 至 12" 
G - 24 小时制的小时,不足二位不补零; 如: "0" 至 "23" 
i - 分钟; 如: "00" 至 "59" 
j - 几日,二位数字,若不足二位不补零; 如: "1" 至 "31" 
l - 星期几,英文全名; 如: "Friday" 
m - 月份,二位数字,若不足二位则在前面补零; 如: "01" 至 "12" 
n - 月份,二位数字,若不足二位则不补零; 如: "1" 至 "12" 
M - 月份,三个英文字母; 如: "Jan" 
s - 秒; 如: "00" 至 "59" 
S - 字尾加英文序数,二个英文字母; 如: "th","nd" 
t - 指定月份的天数; 如: "28" 至 "31" 
U - 总秒数 
w - 数字型的星期几,如: "0" (星期日) 至 "6" (星期六) 
Y - 年,四位数字; 如: "1999" 
y - 年,二位数字; 如: "99" 

z - 一年中的第几天; 如: "0" 至 "365"

 

http://www.php.net/manual/zh/function.date.php

 

document width/height

网页可见区域宽: document.body.clientWidth;
网页可见区域高: document.body.clientHeight;
网页可见区域宽:
document.body.offsetWidth    (包括边线的宽);
网页可见区域高:
document.body.offsetHeight   (包括边线的宽);
网页正文全文宽: document.body.scrollWidth;
网页正文全文高: document.body.scrollHeight;
网页被卷去的高: document.body.scrollTop;
网页被卷去的左: document.body.scrollLeft;
网页正文部分上: window.screenTop;
网页正文部分左: window.screenLeft;
屏幕分辨率的高: window.screen.height;
屏幕分辨率的宽: window.screen.width;
屏幕可用工作区高度: window.screen.availHeight;
屏幕可用工作区宽度:window.screen.availWidth;

scrollHeight: 获取对象的滚动高度。  
scrollLeft:设置或获取位于对象左边界和窗口中目前可见内容的最左端之间的距离
scrollTop:设置或获取位于对象最顶端和窗口中可见内容的最顶端之间的距离
scrollWidth:获取对象的滚动宽度
offsetHeight:获取对象相对于版面或由父坐标 offsetParent 属性指定的父坐标的高度
offsetLeft:获取对象相对于版面或由 offsetParent 属性指定的父坐标的计算左侧位置
offsetTop:获取对象相对于版面或由 offsetTop
属性指定的父坐标的计算顶端位置  
event.clientX 相对文档的水平座标
event.clientY 相对文档的垂直座标

event.offsetX 相对容器的水平坐标
event.offsetY 相对容器的垂直坐标  
document.documentElement.scrollTop 垂直方向滚动的值
event.clientX+document.documentElement.scrollTop
相对文档的水平座标+垂直方向滚动的量

要获取当前页面的滚动条纵坐标位置,用:
document.documentElement.scrollTop;
而不是:
document.body.scrollTop;
documentElement 对应的是 html 标签,而 body 对应的是 body 标签

应用: Math.max(document.documentElement.scrollTop, document.body.scrollTop)