Menu
Woocommerce Menu

SmartUpload相关类的说明,虚拟主机需要备案吗

0 Comment


㈠ File类

虚拟主机需要备案吗?我们在购买域名空间的时候,有时会遇到虚拟主机备案的问题,有些虚拟主机需要备案,有些虚拟主机不需要备案,这就让一些站长们困惑了。虚拟主机需要备案后才能访问吗?

文件管理

创建、复制、删除、移动、查看、编辑、压缩、查找

  这个类包装了一个上传文件的所有信息。通过它,可以得到上传文件的文件名、文件大小、扩展名、文件数据等信息。

网站备案是工信部要求的,主要是为了规范网络安全化,维护网站经营者的合法权益,保障网民的合法利益。凡是使用国内空间的网站域名都需要备案,更明确的说是,只要域名绑定在国内的服务器(虚拟主机)上,就需要ICP备案,否则不需要。

一、Linux目录结构

Windows: 以多根的方式组织文件 C:\ D:\ E:\
Linux: 以单根的方式组织文件 /

/目录结构: FSH (Filesystem Hierarchy Standard)

[root@tianyun ~]# ls /
bin     dev   lib          media  net   root     srv  usr
boot    etc   lib64       misc   opt   sbin     sys  var
cgroup  home  lost+found  mnt    proc  selinux  tmp

  注:下图为Centos7目录结构

图片 1

bin                    普通用户使用的命令 /bin/ls, /bin/date
sbin                  管理员使用的命令 /sbin/service 
dev                    设备文件 /dev/sda,/dev/sda1,/dev/tty1,/dev/tty2,/dev/pts/1, /dev/zero, /dev/null, /dev/random
root                   root用户的HOME
home                 存储普通用户家目录    
lost+found          fsck修复时,存储没有链接的文件或目录
proc                 虚拟的文件系统,反映出来的是内核,进程信息或实时状态 

usr                  系统文件,相当于C:\Windows
                     /usr/local     软件安装的目录,相当于C:\Program
                     /usr/bin      普通用户使用的应用程序
                     /usr/sbin     管理员使用的应用程序
                     /usr/lib      库文件Glibc
                     /usr/lib64   库文件Glibc
boot                存放的系统启动相关的文件,例如kernel,grub(引导装载程序)
etc                  配置文件(系统相关如网络/etc/sysconfig/network,应用相关配置文件如/etc/ssh/sshd_config...)
lib                   库文件Glibc
lib64                库文件Glibc
tmp                临时文件(全局可写:进程产生的临时文件)   
var                存放的是一些变化文件,比如数据库,日志,邮件....
                    mysql:              /var/lib/mysql
                    vsftpd:            /var/ftp
                    mail:                /var/spool/mail
                    cron:                /var/spool/cron
                    log:                /var/log
                    临时文件:     /var/tmp(进程产生的临时文件)  

==设备(主要指存储设备)挂载目录==
media               移动设备默认的挂载点
mnt               手工挂载设备的挂载点
misc                automount进程挂载
net                automount进程挂载

  File类主要提供以下方法:

虚拟主机需要备案吗?虚拟主机怎么备案?只要联系当时购买的空间商就可以,正规的空间商都会提供免费的备案帮助的,只要按他们的要求提供备案所需要的资料就可以,备案一般需要20天左右的时间,具体快慢看各个地方的工信部备案积压情况,积压少就快。

命令存储位置:

/bin              普通用户使用的命令 /bin/ls, /bin/date           RHEL7淘汰
/sbin             管理员使用的命令                                RHEL7淘汰
/usr/bin          普通用户使用的应用程序
/usr/sbin         管理员使用的应用程序

1、saveAs作用:将文件换名另存。

域名备案好后,还要把域名和空间绑定到一起,也就是做一下域名解析和空间绑定这两个操作。域名首先要解析到空间上,域名解析就是把域名指向网站空间IP,让人们通过注册的域名可以方便地访问到网站一种服务。免费域名解析服务由DNS服务器完成。域名解析作一个A记录解析就可以了。解析的时候可以做一个加WWW和不加WWW的域名解析。那样带WWW和不带WWW的域名就都能访问网站了。

库文件存储位置:

/lib      库文件Glibc RHEL7淘汰
/lib64      库文件Glibc RHEL7淘汰
/usr/lib   库文件Glibc
/usr/lib64   库文件Glibc

原型:

接下来空间还要绑定域名时,未备案的域名绑定国内主机IP后并不会生效,只有等你备案之后才会生效
。一般的空间服务商都会提供空间管理控制面板,控制面板会有一项功能,就是绑定域名。大部分都是在域名注册查询会员管理中心,用户登录进去,一般是主机管理那里有相关域名绑定的,如果您的空间服务商没有给你提供控制面板,或没有提供域名绑定的功能,那只能把域名发给空间服务商,让服务商帮你手动操作去绑定域名了。

***文件时间

  ls -l 文件名 仅看的是文件的修改时间

  Linux文件有四种时间:

   # stat anaconda-ks.cfg
//查看文件的详细属性(其中包括文件时间属性)
访问时间:atime, 查看内容 //RHEL6会延后修改atime
修改时间:mtime,修改内容
改变时间:ctime, 文件属性,比如权限
删除时间:dtime, 文件被删除的时间

[root@root ~]# ls -l install.log
-rw-r--r-- 1 root root 34793 10-23 13:49 install.log

[root@root ~]# stat install.log
  File: “install.log”
  Size: 34793           Blocks: 80         IO Block: 4096   一般文件
Device: 802h/2050d      Inode: 65282       Links: 1
Access: (0644/-rw-r--r--)  Uid: (    0/    root)   Gid: (    0/    root)
Access: 2012-10-23 16:53:20.000000000 +0800
Modify: 2012-10-23 13:49:46.000000000 +0800
Change: 2012-10-23 13:49:52.000000000 +0800

注:RHEL6开始relatime,atime延迟修改,必须满足其中一个条件:
1.
自上次atime修改后,已达到86400秒;

  1. 发生写操作时;

public void saveAs(java.lang.String destFilePathName)

域名需要备案后才能访问国内空间吗?域名如果要解析到国内空间,那域名必须要备案后可以访问国内空间的。域名如果解析到海外或香港的空间,域名不需要备案。解析生效后就可以访问网站了。

***文件类型:

通过颜色判断文件的类型是不一定正确的!!!
Linux系统中文件是没有扩展名!!!

 

方法一:

ls -l 文件名    //看第一个字符
-    普通文件(文本文件,二进制文件,压缩文件,电影,图片。。。)
d    目录文件(蓝色)
b    设备文件(块设备)存储设备硬盘,U盘 /dev/sda, /dev/sda1
c    设备文件(字符设备)打印机,终端 /dev/tty1
s    套接字文件
p    管道文件
l    链接文件(淡蓝色)

[root@root ~]# ll -d /etc/hosts /bin/ls /home /dev/sda /dev/tty1 /etc/grub2.cfg /dev/log /run/dmeventd-client
-rwxr-xr-x.  1 root root 117616 Nov 20  2015 /bin/ls
srw-rw-rw-   1 root root      0 Mar 14  2017 /dev/log
brw-rw----   1 root disk   8, 0 Mar 14 09:03 /dev/sda
crw--w----   1 root tty    4, 1 Mar 14 09:03 /dev/tty1
lrwxrwxrwx.  1 root root     22 Dec 21 01:40 /etc/grub2.cfg -> ../boot/grub2/grub.cfg
-rw-r--r--   1 root root    392 Feb 22 15:51 /etc/hosts
drwxr-xr-x. 10 root root   4096 Mar 14 11:00 /home

public void saveAs(java.lang.String destFilePathName, int optionSaveAs)

方法二:file

[root@localhost ~]# file /etc/hosts
/etc/hosts: ASCII text

[root@localhost ~]# file /bin/ls
/bin/ls: ELF 64-bit LSB executable, x86-64, version 1 (SYSV), dynamically linked (uses shared libs), for GNU/Linux 2.6.32, BuildID[sha1]=aa7ff68f13de25936a098016243ce57c3c982e06, stripped

[root@localhost ~]# file /dev/sda
/dev/sda: block special

[root@localhost ~]# file /dev/tty1
/dev/tty1: character special

[root@localhost ~]# file /etc/grub2.cfg 
/etc/grub2.cfg: broken symbolic link to `../boot/grub2/grub.cfg'

[root@localhost ~]# file /home
/home: directory

[root@localhost ~]# file /run/dmeventd-client 
/run/dmeventd-client: fifo (named pipe)

其中,destFilePathName是另存的文件名,optionSaveAs是另存的选项,该选项有三个值,分别是SAVEAS_PHYSICAL,SAVEAS_VIRTUAL,SAVEAS_AUTO。SAVEAS_PHYSICAL表明以操作系统的根目录为文件根目录另存文件,SAVEAS_VIRTUAL表明以Web应用程序的根目录为文件根目录另存文件,SAVEAS_AUTO则表示让组件决定,当Web应用程序的根目录存在另存文件的目录时,它会选择SAVEAS_VIRTUAL,否则会选择SAVEAS_PHYSICAL。

二、路径 (定位文件)

你要在哪儿创建文件?
你要将什么文件复制到什么地方?
你要删除什么地方的什么文件?

图片 2

/home/alice/file1 和 /home/bob/file1
不是同一文件!!!
/abc/file5 和 abc/file5
有可能是不一样的!!!

绝对路径: 从/开始的路径 /home/alice/file1
相对路径:
相对于当前目录开始 a.txt ./a.txt
../bob/b.txt
[假如:此时在目录/home/alice]

例如,saveAs(“/upload/sample.zip”,SAVEAS_PHYSICAL)执行后若Web服务器安装在C盘,则另存的文件名实际是c:\upload\sample.zip。而saveAs(“/upload/sample.zip”,SAVEAS_VIRTUAL)执行后若Web应用程序的根目录是webapps/jspsmartupload,则另存的文件名实际是webapps/jspsmartupload/upload/sample.zip。saveAs(“/upload/sample.zip”,SAVEAS_AUTO)执行时若Web应用程序根目录下存在upload目录,则其效果同saveAs(“/upload/sample.zip”,SAVEAS_VIRTUAL),否则同saveAs(“/upload/sample.zip”,SAVEAS_PHYSICAL)。

 三、文件管理

建议:对于Web程序的开发来说,最好使用SAVEAS_VIRTUAL,以便移植。

1. 文件管理之:cd 改变目录

cd                  绝对路径    cd /home/alice     cd ~alice
cd                  相对路径    cd Desktop/abc    cd ..   cd .
=======================================================
cd 专用:
cd -                  返回上次目录    
cd                      直接回家
=======================================================

2、isMissing

2. 文件管理之:创建/复制/移动/删除

作用:这个方法用于判断用户是否选择了文件,也即对应的表单项是否有值。选择了文件时,它返回false。未选文件时,它返回true。

==创建

文件 touch     
# touch file1.txt                             //无则创建,有则修改时间
# touch file3 file4
# touch /home/file10.txt
# touch /home/file5 file6
# touch /home/{zhuzhu,gougou}
# touch file{1..20}
# touch file{a..c}
# touch yang{a,b,c}                      //{}集合,等价touch yanga yangb yangc

目录 mkdir
# mkdir dir1
# mkdir /home/dir2 /home/dir3
# mkdir /home/{dir4,dir5}
# mkdir -v /home/{dir6,dir7}
# mkdir -v /hoem/dir8/111/22
# mkdir -pv /hoem/dir8/111/222    //包括其父母的创建,不会有任何消息输出
# mkdir -pv /home/{yang/{dir1,111},tianyun}

原型:public boolean isMissing()

==复制 cp

Usage: cp [OPTION]... [-T] SOURCE DEST
# cd
# mkdir /home/dir{1,2}
# cp -v install.log /home/dir1
# cp -v install.log /home/dir1/yang.txt
# cp -rv /etc /home/dir1
# cp -v install.log /home/dir90       //没有/home/dir90
# cp -v install.log /home/dir2
# cp -v anaconda-ks.cfg !$
# cp -rv /etc/sysconfig/network-scripts/ifcfg-eth0 /etc/passwd /etc/grub.conf /home/dir2            //将多个文件拷贝到同一个目录
# cp -rv /etc/sysconfig/network-scripts/ifcfg-eth0 /etc/passwd /etc/grub.conf /etc/hosts .
# cp -r /etc /tmp
# cp -rf /etc /tmp
# \cp -r /etc /tmp

[root@localhost ~]#  type -a cp
cp is aliased to `cp -i'
cp is /bin/cp

[root@localhost ~]#  cp -rv /etc/sysconfig/network-scripts/{ifcfg-eth0,ifcfg-eth0.bak}
[root@localhost ~]#  cp -rv /etc/sysconfig/network-scripts/ifcfg-eth0{,-org}
[root@localhost ~]#  cp -rv /etc/sysconfig/network-scripts/{ifcfg-eth0,yang-eth0}

3、getFieldName

==移动 mv

Usage: mv [OPTION]... [-T] SOURCE DEST
# mv file1 /home/dir3               将file2移动到/home/dir3
# mv file2 /home/dir3/file20      将file2移动到/home/dir3,并改名为file20
# mv file4 file5                          将file4重命名为file5,当前位置的移动就是重命名

作用:取HTML表单中对应于此上传文件的表单项的名字。

==删除 rm

示例1:删除/home/dir1       
# cd /home
# rm -rf dir1       
-r 递归
-f force强制
-v 详细过程

示例2:
[root@localhost~]# mkdir /home/dir10
[root@localhost~]# touch /home/dir10/{file2,file3,.file4}
[root@localhost~]# rm -rf /home/dir10/*                                    //不包括隐藏文件
[root@localhost~]# ls /home/dir10/ -a
.  ..  .file4

示例3:
[root@localhost~]# rm -rf file*
[root@localhost~]# rm -rf *.pdf

原型:public String getFieldName()

3. 文件管理之:查看文件内容

==文本文件 (cat tac less more head tail tailf grep ...)
/bin/date
/etc/hosts
/etc/sysconfig/network
/etc/sysconfig/network-scripts/ifcfg-eth0
/etc/passwd
/etc/shadow 
/etc/group
/etc/grub2.cfg
/etc/resolv.conf                     
/etc/profile                            //设置系统环境变量
/etc/bashrc                           //影响bash shell环境
/var/log/messages                   //系统主日志文件
/var/log/secure                     //跟安全相关的日志如ssh登录,本地登录...

cat     
-n  显示行号
-A  包括控制字符(换行符/制表符)
     linux $     
     Windows ^M$

less  more head  tail  tailf
[root@localhost~]# head  /etc/passwd
[root@localhost~]# head -2 /etc/passwd
[root@localhost~]# tail /etc/passwd
[root@localhost~]# tail -1 /etc/passwd
[root@localhost~]# tail /var/log/messages
[root@localhost~]# tail -20 /var/log/messages
[root@localhost~]# tail -f /var/log/secure              //-f 动态查看文件的尾部
[root@localhost~]# tail -F /var/log/secure              //-F 动态查看文件的尾部
注:vim, gedit编辑文件时,索引号会改变

grep 针对文件内容进行过滤
# grep 'root' /etc/passwd
# grep '^root' /etc/passwd
# grep 'bash$' /etc/passwd
# grep 'failure' /var/log/secure

4、getFileName

4. 文件管理之:修改文件内容

[root@localhost~]# ll -a > list.txt
文件编辑器 gedit
文件编辑器 vi, vim, nano 

图片 3

命令模式:
    a. 光标定位 
        hjkl  
        0 $ 
        gg G  
        3G      进入第三行 
        /string (n N 可以循环的)  快速定位到某一行  
        /^d
        /txt$

    b. 文本编辑(少量)
        y        复制  yy 3yy ygg  yG         (以行为单位)
        d        删除 dd 3dd dgg  dG           (以行为单位)    
        p        粘贴
        x        删除光标所在的字符
        D        从光标处删除到行尾
        u        undo撤销
        ^r       redo重做
        r        可以用来修改一个字符

    c. 进入其它模式
        a        进入插入模式
        i        进入插入模式
        o        进入插入模式
        A        进入插入模式

        :        进入末行模式(扩展命令模式)
        v        进入可视模式
        ^v       进入可视块模式
        V        进入可视行模式
        R        进入替换模式


插入模式:


可视块模式:
        块插入(在指定块前加入字符):  选择块,I   在块前插入字符, ESC
        块替换:                                       选择块,r   输入替换的字符  
        块删除:                                       选择块,d | x
        块复制:                                       选择块,y

扩展命令模式:
    a. 保存退出
        :10     进入第10行   
        :w      保存   
        :q      退出    
        :wq     保存并退出      
        :w!     强制保存    
        :q!     不保存并退出       
        :wq!    强制保存退出
        :x      保存并退出   ZZ


    b. 查找替换
        :范围 s/old/new/选项        
        :1,5 s/root/yang/                     从1-5行的root 替换为yang   
        :5,$ s/root/yang/                     $表示最后一行
        :1,$ s/root/yang/g                    =     :% s/root/yang/g    %表示全文  g表示全局
        :% s#/dev/sda#/var/ccc#g
        :,8 s/root/yang/                      从当前行到第8行
        :4,9 s/^#//                           4-9行的开头#替换为空
        :5,10 s/.*/#&/                        5-10前加入#字符  (.*整行   &引用查找的内容)

    c. 读入文件/写文件(另存为)
        :w                                    存储到当前文件
        :w /tmp/aaa.txt                       另存为/tmp/aaa.txt  
        :1,3 w /tmp/2.txt
        :r /etc/hosts                         读入文件到当前行后
        :5 r /etc/hosts                       读入文件到第5行后

    d. 设置环境     
        临时设置:        
        :set nu                                设置行号      
        :set ic                                不区分大小写
        :set ai                                自动缩进
        :set list                              显示控制字符
        :set nonu                              取消设置行号     
        :set noic

       永久的环境:
       /etc/vimrc                             影响所有系统用户
       ~/.vimrc                               影响某一个用户

        # vim ~/.vimrc 
        set ic
        set nu

 

作用:取文件名(不含目录信息)

原型:public String getFileName()

5、getFilePathName

作用:取文件全名(带目录)

原型:public String getFilePathName

6、getFileExt

作用:取文件扩展名(后缀)

原型:public String getFileExt()

7、getSize

作用:取文件长度(以字节计)

原型:public int getSize()

8、getBinaryData

作用:取文件数据中指定位移处的一个字节,用于检测文件等处理。

原型:public byte getBinaryData(int
index)。其中,index表示位移,其值在0到getSize()-1之间。

㈡ Files类

  这个类表示所有上传文件的集合,通过它可以得到上传文件的数目、大小等信息。有以下方法:

1、getCount

作用:取得上传文件的数目。

原型:public int getCount()

2、getFile

作用:取得指定位移处的文件对象File(这是com.jspsmart.upload.File,不是java.io.File,注意区分)。

标签:

发表评论

电子邮件地址不会被公开。 必填项已用*标注

相关文章

网站地图xml地图