亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C# > 正文

C#部署數據庫及IIS站點

2019-10-29 21:03:16
字體:
來源:轉載
供稿:網友

一、前言

最近忙里偷閑,做了一個部署數據庫及IIS網站站點的WPF應用程序工具。 

二、內容

此工具的目的是:

  • 根據.sql文件在本機上部署數據庫
  • 在本機部署IIS站點,包括新建站點,新建應用程序池。只新建而不會對本機上原有的程序池或站點做修改操作

最終樣式:(Check按鈕的作用是防止與本機已有的站點或程序池有沖突)

C#,數據庫,IIS

View:

 

<Window x:Class="AutoWebTool.MainWindow"    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"    xmlns:d="http://schemas.microsoft.com/expression/blend/2008"    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"    xmlns:i="http://schemas.microsoft.com/expression/2010/interactivity"    xmlns:local="clr-namespace:AutoWebTool"  <Grid>    <Grid.RowDefinitions>      <RowDefinition Height="0.5*"/>      <RowDefinition Height="0.5*"/>      <RowDefinition Height="Auto"/>    </Grid.RowDefinitions>    <GroupBox Header="DataBase Configuration" FontSize="15" BorderThickness="3" Margin="5,10" Grid.Row="0">      <Grid>        <Grid.RowDefinitions>          <RowDefinition/>          <RowDefinition/>          <RowDefinition/>          <RowDefinition/>        </Grid.RowDefinitions>        <Grid.ColumnDefinitions>          <ColumnDefinition Width="65*"/>          <ColumnDefinition Width="133*"/>          <ColumnDefinition Width="Auto"/>        </Grid.ColumnDefinitions>        <TextBlock Grid.Row="0" Grid.Column="0" Text="Server Address" HorizontalAlignment="Center" VerticalAlignment="Center" FontSize="15" Height="26" />        <TextBlock Grid.Row="1" Grid.Column="0" Text="User" HorizontalAlignment="Center" VerticalAlignment="Center" FontSize="15" Height="26" />        <TextBlock Grid.Row="2" Grid.Column="0" Text="Password" HorizontalAlignment="Center" VerticalAlignment="Center" FontSize="15" Height="26" />        <TextBlock Grid.Row="3" Grid.Column="0" Text="Script Path" HorizontalAlignment="Center" VerticalAlignment="Center" FontSize="15" Height="26" />        <TextBox Grid.Row="0" Grid.Column="1" Text="{Binding ServerAddress, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}"            HorizontalAlignment="Left" VerticalAlignment="Center" FontSize="15" Width="450" Height="32" />        <TextBox Grid.Row="1" Grid.Column="1" Text="{Binding User, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}"            HorizontalAlignment="Left" VerticalAlignment="Center" FontSize="15" Width="450" Height="32" />        <PasswordBox Grid.Row="2" Grid.Column="1" PasswordChar="*" local:PasswordBoxHelper.Password="{Binding Password, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}"            HorizontalAlignment="Left" VerticalAlignment="Center" FontSize="15" Width="450" Height="32">          <i:Interaction.Behaviors>            <local:PasswordBoxBehavior />          </i:Interaction.Behaviors>        </PasswordBox>        <TextBox Grid.Row="3" Grid.Column="1" Text="{Binding SqlPath, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}"            HorizontalAlignment="Left" VerticalAlignment="Center" FontSize="15" Width="450" Height="32" />        <Button Grid.Row="4" Grid.Column="2" Width="70" Height="25" Margin="0,0,10,0"            HorizontalAlignment="Left" VerticalAlignment="Center" Content="Browse" Click="FilePathBrowse_Click"/>      </Grid>     </GroupBox>    <GroupBox Header="WebSite And Pool" FontSize="15" BorderThickness="3" Margin="5,10" Grid.Row="1">      <Grid>        <Grid.RowDefinitions>          <RowDefinition/>          <RowDefinition/>          <RowDefinition/>          <RowDefinition/>          <RowDefinition/>        </Grid.RowDefinitions>        <Grid.ColumnDefinitions>          <ColumnDefinition Width="65*"/>          <ColumnDefinition Width="133*"/>          <ColumnDefinition Width="Auto"/>        </Grid.ColumnDefinitions>        <TextBlock Grid.Row="0" Grid.Column="0" Text="WebSite Name" HorizontalAlignment="Center" VerticalAlignment="Center" FontSize="15" Height="26" />        <TextBlock Grid.Row="1" Grid.Column="0" Text="WebSite ID" HorizontalAlignment="Center" VerticalAlignment="Center" FontSize="15" Height="26" />        <TextBlock Grid.Row="2" Grid.Column="0" Text="WebSite PhysicalPath" HorizontalAlignment="Center" VerticalAlignment="Center" FontSize="15" Height="26" />        <TextBlock Grid.Row="3" Grid.Column="0" Text="WebSite Port" HorizontalAlignment="Center" VerticalAlignment="Center" FontSize="15" Height="26" />        <TextBlock Grid.Row="4" Grid.Column="0" Text="Application Pool Name" HorizontalAlignment="Center" VerticalAlignment="Center" FontSize="15" Height="26"/>        <TextBox Grid.Row="0" Grid.Column="1" Text="{Binding WebSiteName, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}"            HorizontalAlignment="Left" VerticalAlignment="Center" FontSize="15" Width="450" Height="32" />        <TextBox Grid.Row="1" Grid.Column="1" Text="{Binding WebSiteID, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}"            HorizontalAlignment="Left" VerticalAlignment="Center" FontSize="15" Width="450" Height="32" />        <TextBox Grid.Row="2" Grid.Column="1" Text="{Binding PhysicalPath, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}"            HorizontalAlignment="Left" VerticalAlignment="Center" FontSize="15" Width="450" Height="32" />        <TextBox Grid.Row="3" Grid.Column="1" Text="{Binding WebSitePort, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}"            HorizontalAlignment="Left" VerticalAlignment="Center" FontSize="15" Width="450" Height="32" />        <TextBox Grid.Row="4" Grid.Column="1" Text="{Binding PoolName, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}"            HorizontalAlignment="Left" VerticalAlignment="Center" FontSize="15" Width="450" Height="32" />        <Button Grid.Row="0" Grid.Column="2" Width="70" Height="25" Margin="0,0,10,0"            HorizontalAlignment="Left" VerticalAlignment="Center" Content="Check" Click="WebSiteNameCheck_Click"/>        <Button Grid.Row="1" Grid.Column="2" Width="70" Height="25" Margin="0,0,10,0"            HorizontalAlignment="Left" VerticalAlignment="Center" Content="Check" Click="WebSiteIDCheck_Click"/>        <Button Grid.Row="2" Grid.Column="2" Width="70" Height="25" Margin="0,0,10,0"            HorizontalAlignment="Left" VerticalAlignment="Center" Content="Browse" Click="PathBrowse_Click"/>        <Button Grid.Row="3" Grid.Column="2" Width="70" Height="25" Margin="0,0,10,0"            HorizontalAlignment="Left" VerticalAlignment="Center" Content="Check" Click="WebSitePortCheck_Click"/>        <Button Grid.Row="4" Grid.Column="2" Width="70" Height="25" Margin="0,0,10,0"            HorizontalAlignment="Left" VerticalAlignment="Center" Content="Check" Click="PoolNameCheck_Click"/>      </Grid>    </GroupBox>    <StackPanel Grid.Row="2" Orientation="Horizontal" HorizontalAlignment="Right" VerticalAlignment="Center" Margin="10">      <Button Width="70" Height="25" Content="OK" Click="Deploy_Click"/>      <Button Width="70" Height="25" Content="Cancel" Margin="10,0,0,0" Click="Close_Click"/>    </StackPanel>  </Grid></Window>

View的后臺文件:

using System.Windows;using System.Windows.Controls;using System.Windows.Interactivity;namespace AutoWebTool{  /// <summary>  /// MainWindow.xaml 的交互邏輯  /// </summary>  public partial class MainWindow : Window  {    private AutoGenerationVM _vm;    public MainWindow()    {      InitializeComponent();      DataContext = new AutoGenerationVM();      _vm = DataContext as AutoGenerationVM;    }    private bool sqlPath;    private void FilePathBrowse_Click(object sender, RoutedEventArgs e)    {      sqlPath = _vm.GetSqlFilePath();    }    private void WebSiteNameCheck_Click(object sender, RoutedEventArgs e)    {      var isInUse = _vm.CheckNameAndID();      if (isInUse)      {        MessageBox.Show("1.This name is Empty /r/n2.This name is in use,please change name!");      }      else      {        MessageBox.Show("No Problem!");      }    }    private void WebSiteIDCheck_Click(object sender, RoutedEventArgs e)    {      var isInUse = _vm.CheckNameAndID();      if (isInUse)      {        MessageBox.Show("1.This ID is Empty /r/n2.This ID is in use,please change ID!");      }      else      {        MessageBox.Show("No Problem!");      }    }    private bool physicalPath;    private void PathBrowse_Click(object sender, RoutedEventArgs e)    {      physicalPath = _vm.GetFolderPath();    }    private void WebSitePortCheck_Click(object sender, RoutedEventArgs e)    {      var isInUse = _vm.CheckWebPort();      if (isInUse)      {        MessageBox.Show("1.This port is Empty /r/n2.This port is in use,please change port!");      }      else      {        MessageBox.Show("No Problem!");      }    }    private void PoolNameCheck_Click(object sender, RoutedEventArgs e)    {      var isInUse = _vm.CkeckPoolName();      if (isInUse)      {        MessageBox.Show("1.This pool name is Empty /r/n2.This name is in use,please change name!");      }      else      {        MessageBox.Show("No Problem!");      }    }    private void Deploy_Click(object sender, RoutedEventArgs e)    {      var dataBaseServerAddressChecked = string.IsNullOrEmpty(_vm.ServerAddress);      var dataBaseUserChecked = string.IsNullOrEmpty(_vm.User);      var dataBasePasswordChecked = string.IsNullOrEmpty(_vm.Password);      var dataBaseScriptChecked = sqlPath;      var dataBaseCondition = !dataBaseServerAddressChecked && !dataBaseUserChecked && !dataBasePasswordChecked && !dataBaseScriptChecked;      var webSiteNameAndIDChecked = _vm.CheckNameAndID();      var webSitePortChecked = _vm.CheckWebPort();      var applicationPoolNameChecked = _vm.CkeckPoolName();      var webSiteCondition = !webSiteNameAndIDChecked && !physicalPath && !webSitePortChecked && !applicationPoolNameChecked;      if (dataBaseCondition&& webSiteCondition)      {        _vm.Execute();      }      else {        MessageBox.Show("Please Check Your Input!");      }    }    private void Close_Click(object sender, RoutedEventArgs e)    {      Close();    }  }  public static class PasswordBoxHelper  {    public static readonly DependencyProperty PasswordProperty =      DependencyProperty.RegisterAttached("Password",      typeof(string), typeof(PasswordBoxHelper),      new FrameworkPropertyMetadata(string.Empty, OnPasswordPropertyChanged));    private static void OnPasswordPropertyChanged(DependencyObject sender, DependencyPropertyChangedEventArgs e)    {      var passwordBox = sender as PasswordBox;      string password = (string)e.NewValue;      if (passwordBox != null && passwordBox.Password != password)      {        passwordBox.Password = password;      }    }    public static string GetPassword(DependencyObject dp)    {      return (string)dp.GetValue(PasswordProperty);    }    public static void SetPassword(DependencyObject dp, string value)    {      dp.SetValue(PasswordProperty, value);    }  }  public class PasswordBoxBehavior : Behavior<PasswordBox>  {    protected override void OnAttached()    {      base.OnAttached();      AssociatedObject.PasswordChanged += OnPasswordChanged;    }    private static void OnPasswordChanged(object sender, RoutedEventArgs e)    {      var passwordBox = sender as PasswordBox;      string password = PasswordBoxHelper.GetPassword(passwordBox);      if (passwordBox != null && passwordBox.Password != password)      {        PasswordBoxHelper.SetPassword(passwordBox, passwordBox.Password);      }    }    protected override void OnDetaching()    {      base.OnDetaching();      AssociatedObject.PasswordChanged -= OnPasswordChanged;    }  }}

ViewModel:

using System;using System.DirectoryServices;using System.ComponentModel;using System.Linq;using System.Net;using System.Net.NetworkInformation;using Microsoft.Web.Administration;using System.Windows.Forms;using System.Diagnostics;using System.Data.SqlClient;using System.IO;namespace AutoWebTool{  public class AutoGenerationVM : INotifyPropertyChanged  {    public AutoGenerationVM()    {      _physicalPath = AppDomain.CurrentDomain.BaseDirectory;    }    //DataBase ServerAddress    private string _serverAddress = string.Empty;    public string ServerAddress    {      get { return _serverAddress; }      set      {        if (_serverAddress != value)        {          _serverAddress = value;          NotifyPropertyChanged("ServerAddress");        }      }    }    //DataBase User    private string _user = string.Empty;    public string User    {      get { return _user; }      set      {        if (_user != value)        {          _user = value;          NotifyPropertyChanged("User");        }      }    }    //DataBase Password    private string _password = string.Empty;    public string Password    {      get { return _password; }      set      {        if (_password != value)        {          _password = value;          NotifyPropertyChanged("Password");        }      }    }    //DataBase SQLPath    private string _sqlPath = string.Empty;    public string SqlPath    {      get { return _sqlPath; }      set      {        if (_sqlPath != value)        {          _sqlPath = value;          NotifyPropertyChanged("SqlPath");        }      }    }    public bool GetSqlFilePath() {      var openFileDialog = new OpenFileDialog();      openFileDialog.Filter = "數據庫腳本文件|*.sql";      if (openFileDialog.ShowDialog() == DialogResult.OK)      {        SqlPath = openFileDialog.FileName;      }      return false;    }    //+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++    //WebSite Name    private string _webSiteName = string.Empty;    public string WebSiteName    {      get { return _webSiteName; }      set      {        if (_webSiteName != value)        {          _webSiteName = value;          NotifyPropertyChanged("WebSiteName");        }      }    }    //WebSite ID    private string _webSiteID = string.Empty;    public string WebSiteID    {      get { return _webSiteID; }      set      {        if (_webSiteID != value)        {          _webSiteID = value;          NotifyPropertyChanged("WebSiteID");        }      }    }    /// <summary>    /// Check WebSite Name and ID    /// </summary>    /// <returns></returns>    public bool CheckNameAndID()    {      if (string.IsNullOrEmpty(WebSiteName) || string.IsNullOrEmpty(WebSiteID)) return true;      DirectoryEntry rootEntry = new DirectoryEntry("IIS://localhost/w3svc");      foreach (DirectoryEntry entry in rootEntry.Children)      {        if (entry.SchemaClassName.Equals("IIsWebServer", StringComparison.OrdinalIgnoreCase))        {          if (WebSiteID == entry.Name) {            return true;          }          if (entry.Properties["ServerComment"].Value.ToString() == WebSiteName)          {            return true;          }        }      }      return false;    }    //Physical Path    private string _physicalPath = string.Empty;    public string PhysicalPath    {      get { return _physicalPath; }      set      {        if (_physicalPath != value)        {          _physicalPath = value;          NotifyPropertyChanged("PhysicalPath");        }      }    }    /// <summary>    /// Get Path for WebSite    /// </summary>    public bool GetFolderPath()    {      if (string.IsNullOrEmpty(PhysicalPath)) return true;      var openFolderDialog = new FolderBrowserDialog();      if (openFolderDialog.ShowDialog() == DialogResult.OK)      {        PhysicalPath = openFolderDialog.SelectedPath;      }      return false;    }    //WebSite Port    private string _webSitePort = string.Empty;    public string WebSitePort    {      get { return _webSitePort; }      set      {        if (_webSitePort != value)        {          _webSitePort = value;          NotifyPropertyChanged("WebSitePort");        }      }    }    /// <summary>    /// Check WebSite Port    /// </summary>    /// <returns></returns>    public bool CheckWebPort()    {      try      {        IPGlobalProperties ipProperties = IPGlobalProperties.GetIPGlobalProperties();        IPEndPoint[] ipEndPoints = ipProperties.GetActiveTcpListeners();        foreach (IPEndPoint endPoint in ipEndPoints)        {          if (endPoint.Port == Convert.ToInt32(WebSitePort))          {            return true;          }        }        return false;      }      catch {        return true;      }          }    //Pool Name    private string _poolName = string.Empty;    public string PoolName    {      get { return _poolName; }      set      {        if (_poolName != value)        {          _poolName = value;          NotifyPropertyChanged("PoolName");        }      }    }    /// <summary>    /// Check Application Pool Name    /// </summary>    /// <returns></returns>    public bool CkeckPoolName()    {      if (string.IsNullOrEmpty(PoolName)) return true;      var manager = new ServerManager();      var list = manager.ApplicationPools;      var matchedItem = list.FirstOrDefault(x => x.Name == PoolName);      if (matchedItem != null)        return true;      return false;    }    /// <summary>    /// Execute Script    /// </summary>    public void Execute()    {      //Deploy DataBase      var tmpConn = new SqlConnection();      tmpConn.ConnectionString = "SERVER = " + ServerAddress +"; DATABASE = master; User ID = " + User+ "; Pwd = " + Password+ ";";      var scriptFile = new FileInfo(SqlPath);      var sqlCreateDBQuery = scriptFile.OpenText().ReadToEnd();      SqlCommand myCommand = new SqlCommand(sqlCreateDBQuery, tmpConn);      try      {        tmpConn.Open();        myCommand.ExecuteNonQuery();        MessageBox.Show("Database has been created successfully!","Create Database", MessageBoxButtons.OK,MessageBoxIcon.Information);      }      catch (Exception ex)      {        MessageBox.Show(ex.ToString(), "Create Database", MessageBoxButtons.OK, MessageBoxIcon.Information);        return;      }      finally      {        tmpConn.Close();              }      try      {        //Deploy WebSite and Application Pool        var script = "net start w3svc " +               "& cd c:/Windows/System32/inetsrv " +               "& appcmd add site /name:" + WebSiteName + " /id:" + WebSiteID +               " /physicalPath:" + PhysicalPath + " /bindings:http/*:" + WebSitePort + ":" + WebSiteName +               " & appcmd add apppool /name:" + PoolName + " /managedRuntimeVersion:v4.0 /managedPipelineMode:Integrated" +               " & appcmd set site /site.name:" + WebSiteName + " /[path='/'].applicationPool:" + PoolName;        ProcessStartInfo startInfo = new ProcessStartInfo();        startInfo.WorkingDirectory = @"C:/Windows/System32";        startInfo.FileName = @"C:/Windows/System32/cmd.exe";        startInfo.RedirectStandardInput = true;        startInfo.RedirectStandardOutput = true;        startInfo.RedirectStandardError = true;        startInfo.UseShellExecute = false;        startInfo.Verb = "RunAs";        Process process = new Process();        process.StartInfo = startInfo;        process.Start();        process.StandardInput.WriteLine(script);        process.StandardInput.WriteLine("&exit");        process.StandardInput.Flush();        process.StandardInput.Close();        process.WaitForExit();        MessageBox.Show("IIS WebSite and Application Pool Deployed Successfully!", "Create WebSite and Application Pool", MessageBoxButtons.OK, MessageBoxIcon.Information);      }      catch (Exception ex)      {        MessageBox.Show(ex.ToString(), "Exception", MessageBoxButtons.OK, MessageBoxIcon.Information);      }    }    public event PropertyChangedEventHandler PropertyChanged;    private void NotifyPropertyChanged(string name)    {      PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(name));    }  }}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


注:相關教程知識閱讀請移步到c#教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产成人一区二区三区小说| 国产精品久久久久久久天堂| 91高清在线免费观看| 成人黄色生活片| 欧美成人激情视频免费观看| 欧美午夜激情视频| 亚洲精品国产福利| 亚洲电影免费观看高清完整版在线| 久久免费少妇高潮久久精品99| 亚洲精品456在线播放狼人| 国产极品精品在线观看| 欧美激情在线一区| 亚洲国产成人精品久久久国产成人一区| 国产精品福利网| 91精品视频在线免费观看| 伊人伊成久久人综合网小说| 色综合久久天天综线观看| 97在线精品国自产拍中文| 国产精品免费福利| 久久久久久久成人| 国产精品久久婷婷六月丁香| 欧美最顶级丰满的aⅴ艳星| 狠狠久久亚洲欧美专区| 日韩美女在线观看一区| 亚洲成人国产精品| 欧美高清在线视频观看不卡| 成人精品一区二区三区电影黑人| 欧美与黑人午夜性猛交久久久| 精品久久久免费| 欧美日韩午夜视频在线观看| 亚洲成年人影院在线| 色老头一区二区三区在线观看| www.xxxx精品| 日韩成人av在线| 亚洲欧洲黄色网| 日韩麻豆第一页| 91国内产香蕉| 欧美极品美女电影一区| 国产精品久久久久久久久男| 欧美日韩亚洲一区二区三区| 日韩免费av一区二区| 亚洲福利视频久久| 亚洲天堂av在线免费| 亚洲自拍高清视频网站| 911国产网站尤物在线观看| 久久夜精品va视频免费观看| 欧美激情国产日韩精品一区18| 欧美在线视频观看| 中文字幕日韩免费视频| 久久99精品久久久久久青青91| 国产精品96久久久久久又黄又硬| 97超碰色婷婷| 成人激情视频小说免费下载| 欧美在线性视频| 日韩精品在线视频观看| 欧美激情在线视频二区| 成人有码在线播放| 日韩免费在线观看视频| 国产成人免费av| 亚洲电影中文字幕| 日韩电影中文字幕一区| 亚洲二区在线播放视频| 久久中文字幕在线视频| 亚洲精品乱码久久久久久按摩观| 91网站在线看| 亚洲第一页中文字幕| 欧美另类精品xxxx孕妇| 久久综合网hezyo| 狠狠色狠色综合曰曰| 亚洲成人网av| 亚洲另类欧美自拍| 亚洲国语精品自产拍在线观看| 亚洲一区久久久| 国产精品99久久久久久白浆小说| 成人欧美一区二区三区黑人孕妇| 欧美日韩另类视频| 亚洲最大成人网色| 日韩美女在线观看| 欧美性xxxx极品hd欧美风情| 午夜精品久久久久久99热软件| 538国产精品一区二区在线| 最近2019年日本中文免费字幕| 亚洲欧美一区二区三区在线| 日本精品久久中文字幕佐佐木| 亚洲精品98久久久久久中文字幕| 国产精品自产拍高潮在线观看| 欧美激情久久久| 自拍偷拍亚洲欧美| 免费99精品国产自在在线| 97国产精品视频人人做人人爱| 一本久久综合亚洲鲁鲁| 日韩电影中文字幕一区| 欧美性xxxx极品高清hd直播| 国产主播在线一区| 国产激情视频一区| 欧美精品在线第一页| 国产精品久久久久久久久久三级| 欧美最猛性xxxxx免费| 欧美精品18videos性欧美| 日产日韩在线亚洲欧美| 日本高清视频精品| 欧美极品少妇全裸体| 性欧美长视频免费观看不卡| 4388成人网| 日韩中文字幕在线播放| 精品国产网站地址| 国产视频在线一区二区| 久久久爽爽爽美女图片| 福利微拍一区二区| 91久热免费在线视频| 一本色道久久88综合亚洲精品ⅰ| 久久香蕉国产线看观看av| 555www成人网| 久久久久久久久电影| 欧美成人第一页| 国产精品99久久久久久白浆小说| 亚洲精品久久久久久久久| 2020国产精品视频| 亚洲第一福利在线观看| 欧美性猛交xxxx免费看| 国产精品美女久久久久av超清| 97免费视频在线播放| 久久国产精品网站| 91精品久久久久久久久久入口| 一区二区成人av| 91久久久久久国产精品| 国产精品一区二区久久久| 日韩精品在线私人| 日韩欧美国产视频| 色yeye香蕉凹凸一区二区av| 国产视频丨精品|在线观看| 色偷偷9999www| 欧美亚洲视频一区二区| 疯狂做受xxxx欧美肥白少妇| 69久久夜色精品国产7777| 国产精品日韩久久久久| 日韩精品视频在线| 国产精品91在线观看| 国产精品偷伦视频免费观看国产| 国产精品永久免费| www.日韩不卡电影av| 国产欧美日韩亚洲精品| 韩剧1988免费观看全集| 欧美主播福利视频| 欧美性猛交xxx| 亚洲国产天堂久久综合网| 亚洲国产91精品在线观看| 91高潮在线观看| 97视频免费看| 欧美性受xxxx黑人猛交| 久久久99免费视频| 黄色成人av在线| 欧美激情国产日韩精品一区18| 欧美极品美女视频网站在线观看免费| 亚洲www视频| 欧美日韩国产综合视频在线观看中文| 国产精品日韩欧美大师| 欧美激情免费看| 欧美老女人性视频| 国产精品欧美一区二区| 精品国产精品自拍| 98精品国产自产在线观看| 亚洲电影免费观看高清| 久久网福利资源网站|