欢迎光临
我们一直在努力

DEBIAN(UBUNTU) 无限制一键全自动 DD 安装WINDOWS

特点

突破没有VNC,没有救援模式,内存比dd包小的限制。
使用Debian Live CD中的busybox做中间媒介,经过复杂的处理,使本机的网络参数传进Windows操作系统中,即使没有DHCP能够让Windows获取网络参数,也能让Windows操作系统在开机的第一时间能够连通网络。

系统需求

1)Debian/Ubuntu/CentOS 系统(由GRUB引导)
2)wget 用来下载文件,获取公网IP
3)ip 获取网关,掩码等
4)sed awk grep 处理文本流
5)VNC 安装系统(此项为可选)
6)无DHCP时额外需求: iconv

#Debian/Ubuntu
# 一般自带

#RedHat/CentOS
yum install glibc-common

限制

1)需要定制dd包

默认Administrator账户登录
默认开启远程桌面(默认3389端口)
适当的调整防火墙.(可选)

2)需要相关的虚拟化驱动
VirtIO驱动(备份下载) XEN驱动(备份下载)

3)dd包解压后的体积不能超过机器第一块硬盘的最大容积

使用方法
使用root用户登录,运行以下命令:
wget –no-check-certificate -qO DebianNET.sh ‘https://moeclub.org/attachment/LinuxShell/DebianNET.sh’ && bash DebianNET.sh -dd ‘[Windows dd包直连地址]’

WIN2003 dd包

使用root用户登录,运行以下命令:

wget https://xiaofd.github.io/ddwin.sh && bash ddwin.sh -w http://104.149.171.243/win2003_with_update.gz -d /dev/sda

  1. 镜像账号:Administrator
  2. 密码:80hostkvmlamjj

WIN2012 dd包

使用root用户登录,运行以下命令:

wget https://xiaofd.github.io/ddwin.sh && bash ddwin.sh -w http://104.217.138.74/win2012r2-xiaofd.gz -d /dev/sda

  1. 镜像账号:Administrator
  2. 密码:xiaofd.WIN
Vicer提供的dd包

#在你的机器上全新安装,如果你有VNC,可以看到全部过程。
#在dd的过程中,会卡在分区的界面上,不走进度条,完成后自动重启。

https://moeclub.org/get-win7embx86-auto

# 该包只添加了VirtIO驱动,理论上仅能在KVM,Hyper-V构架下正常运行。
# 如需在其他虚拟化构架下运行,请自行添加相关虚拟化驱动。

注意事项
  1. 远程登陆账号为: Administrator
  2. 远程登陆密码为: Vicer
  3. 仅修改了主机名,可放心使用。(建议自己制作)
  4. 使用的公用网盘,如需长期/大量使用此包请自行备份
  5. 若违反TOS,后果自负
  6. 在磁盘管理中,点击’C‘盘,右键选择’扩展卷‘,可以直接’增加‘C盘的空间
可能用到的命令:

::以管理员身份运行CMD::

::更改用户的密码
net user [用户名] [密码]
::激活 Administrator 账户
net user Administrator /active:yes
::设置 Administrator 账户密码
net user Administrator [新密码]
::添加用户
net user [用户名] [密码] /add
::将用户添加至 Administrator 组
net localgroup Administrators [用户名] /add
::删除用户
net user [用户名] /del

完整代码预览

#!/bin/bash

while [[ $# -ge 1 ]]; do
case $1 in
-v|–ver)
shift
VERtmp=”$1″
shift
;;
-d|–debian|–ubuntu)
shift
vDEBtmp=”$1″
shift
;;
-dd|–ddwin)
shift
ddMode=’1′
URLtmp=”$1″
shift
;;
-p|–password)
shift
WDtmp=”$1″
shift
;;
-a|–auto)
shift
INStmp=’auto’
;;
-m|–manual)
shift
INStmp=’manual’
;;
-apt|–mirror)
shift
isMirror=’1′
tmpMirror=”$1″
shift
;;
-ssl)
shift
tmpSSL=”$1″
shift
;;
*)
echo -ne ” Usage:\n\tbash $0\t-d/–debian [7/\033[33m\033[04mwheezy\033[0m|8/jessie|9/stretch]\n\t\t\t\t-v/–ver [32/\033[33m\033[04mi386\033[0m|64/amd64]\n\t\t\t\t-apt/–mirror\n\t\t\t\t-dd/–ddwin\n\t\t\t\t-a/–auto\n\t\t\t\t-m/–manual\n”
exit 1;
;;
esac
done

[[ $EUID -ne 0 ]] && echo “Error:This script must be run as root!” && exit 1
[[ -f /boot/grub/grub.cfg ]] && GRUBOLD=’0′ && GRUBDIR=’/boot/grub’ && GRUBFILE=’grub.cfg’
[[ -z $GRUBDIR ]] && [[ -f /boot/grub2/grub.cfg ]] && GRUBOLD=’0′ && GRUBDIR=’/boot/grub2′ && GRUBFILE=’grub.cfg’
[[ -z $GRUBDIR ]] && [[ -f /boot/grub/grub.conf ]] && GRUBOLD=’1′ && GRUBDIR=’/boot/grub’ && GRUBFILE=’grub.conf’
[ -z $GRUBDIR -o -z $GRUBFILE ] && echo “Error! Not Found grub path.” && exit 1[[ -n $vDEBtmp ]] && {
[ “$vDEBtmp” == ‘7’ -o “$vDEBtmp” == ‘wheezy’ ] && linuxdists=’debian’ && vDEB=’wheezy’;
[ “$vDEBtmp” == ‘8’ -o “$vDEBtmp” == ‘jessie’ ] && linuxdists=’debian’ && vDEB=’jessie’;
[ “$vDEBtmp” == ‘9’ -o “$vDEBtmp” == ‘stretch’ ] && linuxdists=’debian’ && vDEB=’stretch’;
[[ “$vDEBtmp” == ‘precise’ ]] && linuxdists=’ubuntu’ && vDEB=’precise’;
[[ “$vDEBtmp” == ‘trusty’ ]] && linuxdists=’ubuntu’ && vDEB=’trusty’;
[[ “$vDEBtmp” == ‘wily’ ]] && linuxdists=’ubuntu’ && vDEB=’wily’;
[[ “$vDEBtmp” == ‘xenial’ ]] && linuxdists=’ubuntu’ && vDEB=’xenial’;
[[ “$vDEBtmp” == ‘yakkety’ ]] && linuxdists=’ubuntu’ && vDEB=’yakkety’;
[[ “$vDEBtmp” == ‘zesty’ ]] && linuxdists=’ubuntu’ && vDEB=’zesty’;
}
[[ -n $vDEBtmp ]] && {
[ “$VERtmp” == ’32’ -o “$VERtmp” == ‘i386′ ] && VER=’i386′;
[ “$VERtmp” == ’64’ -o “$VERtmp” == ‘amd64′ ] && VER=’amd64’;
}
[[ -n $ddMode ]] && [[ “$ddMode” == ‘1’ ]] && {
[[ -n $URLtmp ]] && {
linuxdists=’debian’;
vDEB=’jessie’;
VER=’amd64′;
INStmp=’auto’
DDURL=”$URLtmp”
[[ -n $tmpSSL ]] && CURL_SUPPORT=”$tmpSSL”
[[ -z $CURL_SUPPORT ]] && CURL_SUPPORT=’https://moeclub.org/get-curl_udeb_amd64′
} || {
echo ‘Please input vaild URL! ‘
exit 1
}
} || {
ddMode=’0′;
}[[ -z $linuxdists ]] && linuxdists=’debian’
[[ -n $isMirror ]] && [[ “$isMirror” == ‘1’ ]] && [[ -n $tmpMirror ]] && {
tmpDebianMirror=”$(echo -n “$tmpMirror” |grep -Eo ‘.*\.(\w+)’)”
echo -n “$tmpDebianMirror” |grep -q ‘://’
[[ $? -eq ‘0’ ]] && {
DebianMirror=”$(echo -n “$tmpDebianMirror” |awk -F’://’ ‘{print $2}’)”
} || {
DebianMirror=”$(echo -n “$tmpDebianMirror”)”
}
} || {
[[ $linuxdists == ‘debian’ ]] && DebianMirror=’httpredir.debian.org’
[[ $linuxdists == ‘ubuntu’ ]] && DebianMirror=’archive.ubuntu.com’
}
[[ -z $DebianMirrorDirectory ]] && [[ -n $DebianMirror ]] && [[ -n $tmpMirror ]] && {
DebianMirrorDirectory=”$(echo -n “$tmpMirror” |awk -F”${DebianMirror}” ‘{print $2}’ |sed ‘s/\/$//g’)”
}
[[ “$DebianMirrorDirectory” == ‘/’ ]] && [[ -n $DebianMirror ]] && {
[[ $linuxdists == ‘debian’ ]] && DebianMirrorDirectory=’/debian’
[[ $linuxdists == ‘ubuntu’ ]] && DebianMirrorDirectory=’/ubuntu’
}
[[ -z $DebianMirrorDirectory ]] && [[ -n $DebianMirror ]] && {
[[ $linuxdists == ‘debian’ ]] && DebianMirrorDirectory=’/debian’
[[ $linuxdists == ‘ubuntu’ ]] && DebianMirrorDirectory=’/ubuntu’
}[[ -n $INStmp ]] && {
[[ “$INStmp” == ‘auto’ ]] && inVNC=’n’
[[ “$INStmp” == ‘manual’ ]] && inVNC=’y’
}
[[ -n $WDtmp ]] && myPASSWORD=”$WDtmp”[[ -z $vDEB ]] && vDEB=’wheezy’;
[[ -z $VER ]] && VER=’i386′;
[[ -z $myPASSWORD ]] && myPASSWORD=’Vicer’

clear && echo -e “\n\033[36m# Install\033[0m\n”

[[ -z $inVNC ]] && ASKVNC(){
inVNC=’y’;
[[ “$ddMode” == ‘0’ ]] && {
echo -ne “\033[34mCan you login VNC?\033[0m\e[33m[\e[32my\e[33m/n]\e[0m ”
read inVNCtmp
[[ -n “$inVNCtmp” ]] && inVNC=$inVNCtmp
}
[ “$inVNC” == ‘y’ -o “$inVNC” == ‘Y’ ] && inVNC=’y’
[ “$inVNC” == ‘n’ -o “$inVNC” == ‘N’ ] && inVNC=’n’
}[ “$inVNC” == ‘y’ -o “$inVNC” == ‘n’ ] || ASKVNC;[[ $linuxdists == ‘debian’ ]] && LinuxName=’Debian’
[[ $linuxdists == ‘ubuntu’ ]] && LinuxName=’Ubuntu’
[[ “$ddMode” == ‘0’ ]] && {
[[ “$inVNC” == ‘y’ ]] && echo -e “\033[34mManual Mode\033[0m insatll \033[33m$LinuxName\033[0m [\033[33m$vDEB\033[0m] [\033[33m$VER\033[0m] in VNC. ”
[[ “$inVNC” == ‘n’ ]] && echo -e “\033[34mAuto Mode\033[0m insatll \033[33m$LinuxName\033[0m [\033[33m$vDEB\033[0m] [\033[33m$VER\033[0m]. ”
}
[[ “$ddMode” == ‘1’ ]] && {
echo -ne “\033[34mAuto Mode\033[0m insatll \033[33mWindows\033[0m\n[\033[33m$DDURL\033[0m]\n”
}

echo -e “\n[\033[33m$vDEB\033[0m] [\033[33m$VER\033[0m] Downloading…”
[[ -z $DebianMirror ]] && echo -ne “\033[31mError! \033[0mGet debian mirror fail! \n” && exit 1
[[ -z $DebianMirrorDirectory ]] && echo -ne “\033[31mError! \033[0mGet debian mirror directory fail! \n” && exit 1
wget –no-check-certificate -qO ‘/boot/initrd.gz’ “http://$DebianMirror$DebianMirrorDirectory/dists/$vDEB/main/installer-$VER/current/images/netboot/$linuxdists-installer/$VER/initrd.gz”
[[ $? -ne ‘0’ ]] && echo -ne “\033[31mError! \033[0mDownload ‘initrd.gz’ failed! \n” && exit 1
wget –no-check-certificate -qO ‘/boot/linux’ “http://$DebianMirror$DebianMirrorDirectory/dists/$vDEB/main/installer-$VER/current/images/netboot/$linuxdists-installer/$VER/linux”
[[ $? -ne ‘0’ ]] && echo -ne “\033[31mError! \033[0mDownload ‘linux’ failed! \n” && exit 1

DEFAULTNET=”$(ip route show |grep -o ‘default via [0-9]\{1,3\}.[0-9]\{1,3\}.[0-9]\{1,3\}.[0-9]\{1,3\}.*’ |head -n1 |sed ‘s/proto.*\|onlink.*//g’ |awk ‘{print $NF}’)”
[[ -n “$DEFAULTNET” ]] && IPSUB=”$(ip addr |grep ”${DEFAULTNET}” |grep ‘global’ |grep ‘brd’ |head -n1 |grep -o ‘[0-9]\{1,3\}.[0-9]\{1,3\}.[0-9]\{1,3\}.[0-9]\{1,3\}/[0-9]\{1,2\}’)”
IPv4=”$(echo -n “$IPSUB” |cut -d’/’ -f1)”
NETSUB=”$(echo -n “$IPSUB” |grep -o ‘/[0-9]\{1,2\}’)”
GATE=”$(ip route show |grep -o ‘default via [0-9]\{1,3\}.[0-9]\{1,3\}.[0-9]\{1,3\}.[0-9]\{1,3\}’ |head -n1 |grep -o ‘[0-9]\{1,3\}.[0-9]\{1,3\}.[0-9]\{1,3\}.[0-9]\{1,3\}’)”
[[ -n “$NETSUB” ]] && MASK=”$(echo -n ‘128.0.0.0/1,192.0.0.0/2,224.0.0.0/3,240.0.0.0/4,248.0.0.0/5,252.0.0.0/6,254.0.0.0/7,255.0.0.0/8,255.128.0.0/9,255.192.0.0/10,255.224.0.0/11,255.240.0.0/12,255.248.0.0/13,255.252.0.0/14,255.254.0.0/15,255.255.0.0/16,255.255.128.0/17,255.255.192.0/18,255.255.224.0/19,255.255.240.0/20,255.255.248.0/21,255.255.252.0/22,255.255.254.0/23,255.255.255.0/24,255.255.255.128/25,255.255.255.192/26,255.255.255.224/27,255.255.255.240/28,255.255.255.248/29,255.255.255.252/30,255.255.255.254/31,255.255.255.255/32’ |grep -o ‘[0-9]\{1,3\}.[0-9]\{1,3\}.[0-9]\{1,3\}.[0-9]\{1,3\}’${NETSUB}” |cut -d’/’ -f1)”

[[ -n “$GATE” ]] && [[ -n “$MASK” ]] && [[ -n “$IPv4” ]] || {
echo “Not found `ip command`, It will use `route command`.”
ipNum() {
local IFS=’.’
read ip1 ip2 ip3 ip4 <<<“$1″
echo $((ip1*(1<<24)+ip2*(1<<16)+ip3*(1<<8)+ip4))
}

SelectMax(){
ii=0
for IPITEM in `route -n |awk -v OUT=$1 ‘{print $OUT}’ |grep ‘[0-9]\{1,3\}.[0-9]\{1,3\}.[0-9]\{1,3\}.[0-9]\{1,3\}’`
do
NumTMP=”$(ipNum $IPITEM)”
eval “arrayNum[$ii]=’$NumTMP,$IPITEM'”
ii=$[$ii+1]
done
echo ${arrayNum[@]} |sed ‘s/\s/\n/g’ |sort -n -k 1 -t ‘,’ |tail -n1 |cut -d’,’ -f2
}

[[ -z $IPv4 ]] && IPv4=”$(ifconfig |grep ‘Bcast’ |head -n1 |grep -o ‘[0-9]\{1,3\}.[0-9]\{1,3\}.[0-9]\{1,3\}.[0-9]\{1,3\}’ |head -n1)”
[[ -z $GATE ]] && GATE=”$(SelectMax 2)”
[[ -z $MASK ]] && MASK=”$(SelectMax 3)”[[ -n “$GATE” ]] && [[ -n “$MASK” ]] && [[ -n “$IPv4” ]] || {
echo “Error! Not configure network. ”
exit 1
}
}[[ -f /etc/network/interfaces ]] && {
[[ -z “$(sed -n ‘/iface.*inet static/p’ /etc/network/interfaces)” ]] && AutoNet=’1′ || AutoNet=’0′
[[ -d /etc/network/interfaces.d ]] && {
ICFGN=”$(find /etc/network/interfaces.d -name ‘*.cfg’ |wc -l)” || ICFGN=’0′
[[ “$ICFGN” -ne ‘0’ ]] && {
for NetCFG in `ls -1 /etc/network/interfaces.d/*.cfg`
do
[[ -z “$(cat $NetCFG | sed -n ‘/iface.*inet static/p’)” ]] && AutoNet=’1′ || AutoNet=’0′
[[ “$AutoNet” -eq ‘0’ ]] && break
done
}
}
}
[[ -d /etc/sysconfig/network-scripts ]] && {
ICFGN=”$(find /etc/sysconfig/network-scripts -name ‘ifcfg-*’ |grep -v ‘lo’|wc -l)” || ICFGN=’0’
[[ “$ICFGN” -ne ‘0’ ]] && {
for NetCFG in `ls -1 /etc/sysconfig/network-scripts/ifcfg-* |grep -v ‘lo$’ |grep -v ‘:[0-9]\{1,\}’`
do
[[ -n “$(cat $NetCFG | sed -n ‘/BOOTPROTO.*[dD][hH][cC][pP]/p’)” ]] && AutoNet=’1′ || {
AutoNet=’0′ && . $NetCFG
[[ -n $NETMASK ]] && MASK=”$NETMASK”
[[ -n $GATEWAY ]] && GATE=”$GATEWAY”
}
[[ “$AutoNet” -eq ‘0’ ]] && break
done
}
}[[ ! -f $GRUBDIR/$GRUBFILE ]] && echo “Error! Not Found $GRUBFILE. ” && exit 1[[ ! -f $GRUBDIR/$GRUBFILE.old ]] && [[ -f $GRUBDIR/$GRUBFILE.bak ]] && mv -f $GRUBDIR/$GRUBFILE.bak $GRUBDIR/$GRUBFILE.old
mv -f $GRUBDIR/$GRUBFILE $GRUBDIR/$GRUBFILE.bak
[[ -f $GRUBDIR/$GRUBFILE.old ]] && cat $GRUBDIR/$GRUBFILE.old >$GRUBDIR/$GRUBFILE || cat $GRUBDIR/$GRUBFILE.bak >$GRUBDIR/$GRUBFILE[[ “$GRUBOLD” == ‘0’ ]] && {
CFG0=”$(awk ‘/menuentry /{print NR}’ $GRUBDIR/$GRUBFILE|head -n 1)”
CFG2=”$(awk ‘/menuentry /{print NR}’ $GRUBDIR/$GRUBFILE|head -n 2 |tail -n 1)”
CFG1=””
for CFGtmp in `awk ‘/}/{print NR}’ $GRUBDIR/$GRUBFILE`
do
[ $CFGtmp -gt “$CFG0” -a $CFGtmp -lt “$CFG2″ ] && CFG1=”$CFGtmp”;
done
[[ -z “$CFG1” ]] && {
echo “Error! read $GRUBFILE. ”
exit 1
}
sed -n “$CFG0,$CFG1″p $GRUBDIR/$GRUBFILE >/tmp/grub.new
[[ -f /tmp/grub.new ]] && [[ “$(grep -c ‘{‘ /tmp/grub.new)” -eq “$(grep -c ‘}’ /tmp/grub.new)” ]] || {
echo -ne “\033[31mError! \033[0mNot configure $GRUBFILE. \n”
exit 1
}

sed -i “/menuentry.*/c\menuentry\ \’Install OS \[$vDEB\ $VER\]\’\ –class debian\ –class\ gnu-linux\ –class\ gnu\ –class\ os\ \{” /tmp/grub.new
[[ “$(grep -c ‘{‘ /tmp/grub.new)” -eq “$(grep -c ‘}’ /tmp/grub.new)” ]] || {
echo “Error! configure append $GRUBFILE. ”
exit 1
}
sed -i “/echo.*Loading/d” /tmp/grub.new
}

[[ “$GRUBOLD” == ‘1’ ]] && {
CFG0=”$(awk ‘/title /{print NR}’ $GRUBDIR/$GRUBFILE|head -n 1)”
CFG1=”$(awk ‘/title /{print NR}’ $GRUBDIR/$GRUBFILE|head -n 2 |tail -n 1)”
[[ -n $CFG0 ]] && [ -z $CFG1 -o $CFG1 == $CFG0 ] && sed -n “$CFG0,$”p $GRUBDIR/$GRUBFILE >/tmp/grub.new
[[ -n $CFG0 ]] && [ -z $CFG1 -o $CFG1 != $CFG0 ] && sed -n “$CFG0,$CFG1″p $GRUBDIR/$GRUBFILE >/tmp/grub.new
[[ ! -f /tmp/grub.new ]] && echo “Error! configure append $GRUBFILE. ” && exit 1
sed -i “/title.*/c\title\ \’Install OS \[$vDEB\ $VER\]\'” /tmp/grub.new
sed -i ‘/^#/d’ /tmp/grub.new
}[[ -n “$(grep ‘initrd.*/’ /tmp/grub.new |awk ‘{print $2}’ |tail -n 1 |grep ‘^/boot/’)” ]] && Type=’InBoot’ || Type=’NoBoot’

LinuxKernel=”$(grep ‘linux.*/’ /tmp/grub.new |awk ‘{print $1}’ |head -n 1)”
[[ -z $LinuxKernel ]] && LinuxKernel=”$(grep ‘kernel.*/’ /tmp/grub.new |awk ‘{print $1}’ |head -n 1)”
LinuxIMG=”$(grep ‘initrd.*/’ /tmp/grub.new |awk ‘{print $1}’ |tail -n 1)”

[[ “$Type” == ‘InBoot’ ]] && {
sed -i “/$LinuxKernel.*\//c\\\t$LinuxKernel\\t\/boot\/linux auto=true hostname=$linuxdists domain= — quiet” /tmp/grub.new
sed -i “/$LinuxIMG.*\//c\\\t$LinuxIMG\\t\/boot\/initrd.gz” /tmp/grub.new
}[[ “$Type” == ‘NoBoot’ ]] && {
sed -i “/$LinuxKernel.*\//c\\\t$LinuxKernel\\t\/linux auto=true hostname=$linuxdists domain= — quiet” /tmp/grub.new
sed -i “/$LinuxIMG.*\//c\\\t$LinuxIMG\\t\/initrd.gz” /tmp/grub.new
}

sed -i ‘$a\\n’ /tmp/grub.new

[[ “$inVNC” == ‘n’ ]] && {
GRUBPATCH=’0′
[ -f /etc/network/interfaces -o -d /etc/sysconfig/network-scripts ] && {
sed -i ”${CFG0}’i\\n’ $GRUBDIR/$GRUBFILE
sed -i ”${CFG0}’r /tmp/grub.new’ $GRUBDIR/$GRUBFILE
[[ -z $AutoNet ]] && echo “Error, Not found interfaces config.” && exit 1
[[ -f $GRUBDIR/grubenv ]] && sed -i ‘s/saved_entry/#saved_entry/g’ $GRUBDIR/grubenv
[[ -d /boot/tmp ]] && rm -rf /boot/tmp
mkdir -p /boot/tmp/
cd /boot/tmp/
gzip -d < ../initrd.gz | cpio –extract –verbose –make-directories –no-absolute-filenames >>/dev/null 2>&1
cat >/boot/tmp/preseed.cfg<<eof
d-i debian-installer/locale string en_US
d-i console-setup/layoutcode string us</eof

d-i keyboard-configuration/xkb-keymap string us

d-i netcfg/choose_interface select auto

d-i netcfg/disable_autoconfig boolean true
d-i netcfg/dhcp_failed note
d-i netcfg/dhcp_options select Configure network manually
d-i netcfg/get_ipaddress string $IPv4
d-i netcfg/get_netmask string $MASK
d-i netcfg/get_gateway string $GATE
d-i netcfg/get_nameservers string 8.8.8.8
d-i netcfg/no_default_route boolean true
d-i netcfg/confirm_static boolean true

d-i hw-detect/load_firmware boolean false

d-i mirror/country string manual
d-i mirror/http/hostname string $DebianMirror
d-i mirror/http/directory string $DebianMirrorDirectory
d-i mirror/http/proxy string

d-i passwd/root-login boolean ture
d-i passwd/make-user boolean false
d-i passwd/root-password password $myPASSWORD
d-i passwd/root-password-again password $myPASSWORD
d-i user-setup/allow-password-weak boolean true
d-i user-setup/encrypt-home boolean false

d-i clock-setup/utc boolean true
d-i time/zone string US/Eastern
d-i clock-setup/ntp boolean true

d-i preseed/early_command string anna-install libfuse2-udeb fuse-udeb ntfs-3g-udeb fuse-modules-3.16.0-4-amd64-di
d-i partman/early_command string \
debconf-set partman-auto/disk “\$(list-devices disk |head -n1)”; \
wget -qO- ‘$DDURL’ |gunzip -dc |/bin/dd of=\$(list-devices disk |head -n1); \
mount.ntfs-3g \$(list-devices partition |head -n1) /mnt; \
cp -f ‘/net.bat’ ‘/mnt/ProgramData/Microsoft/Windows/Start Menu/Programs/Startup/net.bat’; \
/sbin/reboot; \
debconf-set grub-installer/bootdev string “\$(list-devices disk |head -n1)”; \
umount /media || true; \

d-i partman/mount_style select uuid
d-i partman-auto/init_automatically_partition select Guided – use entire disk
d-i partman-auto/method string regular
d-i partman-lvm/device_remove_lvm boolean true
d-i partman-md/device_remove_md boolean true
d-i partman-auto/choose_recipe select atomic
d-i partman-partitioning/confirm_write_new_label boolean true
d-i partman/choose_partition select finish
d-i partman-lvm/confirm boolean true
d-i partman-lvm/confirm_nooverwrite boolean true
d-i partman/confirm boolean true
d-i partman/confirm_nooverwrite boolean true

d-i debian-installer/allow_unauthenticated boolean true

tasksel tasksel/first multiselect minimal
d-i pkgsel/update-policy select none
d-i pkgsel/include string openssh-server
d-i pkgsel/upgrade select none

popularity-contest popularity-contest/participate boolean false

d-i grub-installer/only_debian boolean true
d-i grub-installer/bootdev string default
d-i finish-install/reboot_in_progress note
d-i debian-installer/exit/reboot boolean true
d-i preseed/late_command string \
sed -i ‘s/^.*PermitRootLogin.*/PermitRootLogin yes/g’ /target/etc/ssh/sshd_config; \
sed -i ‘s/^.*PasswordAuthentication.*/PasswordAuthentication yes/g’ /target/etc/ssh/sshd_config;
EOF
[[ “$AutoNet” -eq ‘1’ ]] && {
sed -i ‘/netcfg\/disable_autoconfig/d’ /boot/tmp/preseed.cfg
sed -i ‘/netcfg\/dhcp_options/d’ /boot/tmp/preseed.cfg
sed -i ‘/netcfg\/get_.*/d’ /boot/tmp/preseed.cfg
sed -i ‘/netcfg\/confirm_static/d’ /boot/tmp/preseed.cfg
}
[[ “$vDEB” == ‘trusty’ ]] && GRUBPATCH=’1′
[[ “$vDEB” == ‘wily’ ]] && GRUBPATCH=’1′
[[ “$GRUBPATCH” == ‘1’ ]] && {
sed -i ‘s/^d-i\ grub-installer\/bootdev\ string\ default//g’ /boot/tmp/preseed.cfg
}
[[ “$GRUBPATCH” == ‘0’ ]] && {
sed -i ‘s/debconf-set\ grub-installer\/bootdev.*\”\;//g’ /boot/tmp/preseed.cfg
}
[[ “$vDEB” == ‘xenial’ ]] && {
sed -i ‘s/^d-i\ clock-setup\/ntp\ boolean\ true/d-i\ clock-setup\/ntp\ boolean\ false/g’ /boot/tmp/preseed.cfg
}
[[ “$linuxdists” == ‘debian’ ]] && {
sed -i ‘/user-setup\/allow-password-weak/d’ /boot/tmp/preseed.cfg
sed -i ‘/user-setup\/encrypt-home/d’ /boot/tmp/preseed.cfg
sed -i ‘/pkgsel\/update-policy/d’ /boot/tmp/preseed.cfg
sed -i ‘s/umount\ \/media.*true\;\ //g’ /boot/tmp/preseed.cfg
}
[[ “$ddMode” == ‘1’ ]] && {
[[ “$AutoNet” -eq ‘1’ ]] && echo -ne “@ECHO OFF\r\ncd\040\057d\040\042\045ProgramData\045\057Microsoft\057Windows\057Start\040Menu\057Programs\057Startup\042\r\ndel\040\057f\040\057q\040net\056bat\r\n\r\n” >’/boot/tmp/net.tmp’;
[[ “$AutoNet” -eq ‘0’ ]] && echo -ne “@ECHO OFF\r\ncd\056\076\045windir\045\GetAdmin\r\nif\040exist\040\045windir\045\GetAdmin\040\050del\040\057f\040\057q\040\042\045windir\045\GetAdmin\042\051\040else\040\050\r\necho\040CreateObject^\050\042Shell\056Application\042^\051\056ShellExecute\040\042\045~s0\042\054\040\042\045\052\042\054\040\042\042\054\040\042runas\042\054\040\061\040\076\076\040\042\045temp\045\Admin\056vbs\042\r\n\042\045temp\045\Admin\056vbs\042\r\ndel\040\057f\040\057q\040\042\045temp\045\Admin\056vbs\042\r\nexit\040\057b\040\062\051\r\nfor\040\057f\040\042tokens=\063\052\042\040\045\045i\040in\040\050\047netsh\040interface\040show\040interface\040^|more\040+3\040^|findstr\040\057R\040\042本地\056\052\040以太\056\052\040Local\056\052\040Ethernet\042\047\051\040do\040\050set\040EthName=\045\045j\051\r\nnetsh\040-c\040interface\040ip\040set\040address\040name=\042\045EthName\045\042\040source=static\040address=$IPv4\040mask=$MASK\040gateway=$GATE\r\nnetsh\040-c\040interface\040ip\040add\040dnsservers\040name=\042\045EthName\045\042 address=\070\056\070\056\070\056\070\040index=1\040validate=no\r\nnetsh\040-c\040interface\040ip\040add\040dnsservers\040name=\042\045EthName\045\042\040address=\070\056\070\056\064\056\064\040index=2\040validate=no\r\ncd\040\057d\040\042\045ProgramData\045\057Microsoft\057Windows\057Start\040Menu\057Programs\057Startup\042\r\ndel\040\057f\040\057q\040net\056bat\r\n\r\n” >’/boot/tmp/net.tmp’;
iconv -f ‘UTF-8’ -t ‘GBK’ ‘/boot/tmp/net.tmp’ -o ‘/boot/tmp/net.bat’
rm -rf ‘/boot/tmp/net.tmp’
echo “$DDURL” |grep -q ‘^https://’
[[ $? -eq ‘0’ ]] && {
echo -ne ‘\nAdd curl support…\n’
[[ -n $CURL_SUPPORT ]] && {
wget –no-check-certificate -qO- “$CURL_SUPPORT” |tar -x
[[ ! -f /boot/tmp/usr/bin/curl ]] && echo ‘Error! CURL_SUPPORT.’ && exit 1;
sed -i ‘s/wget\ -qO-/\/usr\/bin\/curl -ksSL/g’ /boot/tmp/preseed.cfg
[[ $? -eq ‘0’ ]] && echo ‘Success! \n\n’
} || {
echo -ne ‘Not curl support package! \n\n’
exit 1
}
}
}
[[ “$ddMode” == ‘0’ ]] && {
sed -i ‘/anna-install/d’ /boot/tmp/preseed.cfg
sed -i ‘s/wget.*\/sbin\/reboot\;\ //g’ /boot/tmp/preseed.cfg
}
rm -rf ../initrd.gz
find . | cpio -H newc –create –verbose | gzip -9 > ../initrd.gz
rm -rf /boot/tmp
}
}

[[ “$inVNC” == ‘y’ ]] && {
sed -i ‘$i\\n’ $GRUBDIR/$GRUBFILE
sed -i ‘$r /tmp/grub.new’ $GRUBDIR/$GRUBFILE
echo -e “\n\033[33m\033[04mIt will reboot! \nPlease look at VNC! \nSelect\033[0m\033[32m Install OS [$vDEB $VER] \033[33m\033[4mto install system.\033[04m\n\n\033[31m\033[04mThere is some information for you.\nDO NOT CLOSE THE WINDOW! \033[0m\n”
echo -e “\033[35mIPv4\t\tNETMASK\t\tGATEWAY\033[0m”
echo -e “\033[36m\033[04m$IPv4\033[0m\t\033[36m\033[04m$MASK\033[0m\t\033[36m\033[04m$GATE\033[0m\n\n”

read -n 1 -p “Press Enter to reboot…” INP
if [[ “$INP” != ” ]] ; then
echo -ne ‘\b \n’
echo “”;
fi
}

chown root:root $GRUBDIR/$GRUBFILE
chmod 444 $GRUBDIR/$GRUBFILE

sleep 3 && reboot >/dev/null 2>&1

赞(0)
未经允许不得转载:站长电台 » DEBIAN(UBUNTU) 无限制一键全自动 DD 安装WINDOWS
分享到: 更多 (0)

评论 抢沙发

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址