亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? packet_id.c

?? OpenVPN is a robust and highly flexible tunneling application that uses all of the encryption, authe
?? C
字號:
/* *  OpenVPN -- An application to securely tunnel IP networks *             over a single TCP/UDP port, with support for SSL/TLS-based *             session authentication and key exchange, *             packet encryption, packet authentication, and *             packet compression. * *  Copyright (C) 2002-2004 James Yonan <jim@yonan.net> * *  This program is free software; you can redistribute it and/or modify *  it under the terms of the GNU General Public License as published by *  the Free Software Foundation; either version 2 of the License, or *  (at your option) any later version. * *  This program is distributed in the hope that it will be useful, *  but WITHOUT ANY WARRANTY; without even the implied warranty of *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the *  GNU General Public License for more details. * *  You should have received a copy of the GNU General Public License *  along with this program (see the file COPYING included with this *  distribution); if not, write to the Free Software Foundation, Inc., *  59 Temple Place, Suite 330, Boston, MA  02111-1307  USA *//* * These routines are designed to catch replay attacks, * where a man-in-the-middle captures packets and then * attempts to replay them back later. * * We use the "sliding-window" algorithm, similar * to IPSec. */#ifdef WIN32#include "config-win32.h"#else#include "config.h"#endif#ifdef USE_CRYPTO#include "syshead.h"#include "packet_id.h"#include "misc.h"#include "integer.h"#include "memdbg.h"/* * Special time_t value that indicates that * sequence number has expired. */#define SEQ_UNSEEN  ((time_t)0)#define SEQ_EXPIRED ((time_t)1)voidpacket_id_init (struct packet_id *p, int seq_backtrack, int time_backtrack){  msg (D_PID_DEBUG_LOW, "PID packet_id_init seq_backtrack=%d time_backtrack=%d",       seq_backtrack,       time_backtrack);  ASSERT (p);  CLEAR (*p);  if (seq_backtrack)    {      ASSERT (MIN_SEQ_BACKTRACK <= seq_backtrack && seq_backtrack <= MAX_SEQ_BACKTRACK);      ASSERT (MIN_TIME_BACKTRACK <= time_backtrack && time_backtrack <= MAX_TIME_BACKTRACK);      CIRC_LIST_ALLOC (p->rec.seq_list, struct seq_list, seq_backtrack);      p->rec.seq_backtrack = seq_backtrack;      p->rec.time_backtrack = time_backtrack;    }  p->rec.initialized = true;}voidpacket_id_free (struct packet_id *p){  ASSERT (p);  msg (D_PID_DEBUG_LOW, "PID packet_id_free");  if (p->rec.seq_list)    free (p->rec.seq_list);  CLEAR (*p);}voidpacket_id_add (struct packet_id_rec *p, const struct packet_id_net *pin){  const time_t local_now = now;  if (p->seq_list)    {      packet_id_type diff;      /*       * If time value increases, start a new       * sequence number sequence.       */      if (!CIRC_LIST_SIZE (p->seq_list)	  || pin->time > p->time	  || (pin->id >= (packet_id_type)p->seq_backtrack	      && pin->id - (packet_id_type)p->seq_backtrack > p->id))	{	  p->time = pin->time;	  p->id = 0;	  if (pin->id > (packet_id_type)p->seq_backtrack)	    p->id = pin->id - (packet_id_type)p->seq_backtrack;	  CIRC_LIST_RESET (p->seq_list);	}      while (p->id < pin->id)	{	  CIRC_LIST_PUSH (p->seq_list, SEQ_UNSEEN);	  ++p->id;	}      diff = p->id - pin->id;      if (diff < (packet_id_type) CIRC_LIST_SIZE (p->seq_list)	  && local_now > SEQ_EXPIRED)	CIRC_LIST_ITEM (p->seq_list, diff) = local_now;    }  else    {      p->time = pin->time;      p->id = pin->id;    }}/* * Expire sequence numbers which can no longer * be accepted because they would violate * time_backtrack. */voidpacket_id_reap (struct packet_id_rec *p){  const time_t local_now = now;  if (p->time_backtrack)    {      int i;      bool expire = false;      for (i = 0; i < CIRC_LIST_SIZE (p->seq_list); ++i)	{	  const time_t t = CIRC_LIST_ITEM (p->seq_list, i);	  if (t == SEQ_EXPIRED)	    break;	  if (!expire && t && t + p->time_backtrack < local_now)	    expire = true;	  if (expire)	    CIRC_LIST_ITEM (p->seq_list, i) = SEQ_EXPIRED;	}    }  p->last_reap = local_now;}/* * Return true if packet id is ok, or false if * it is a replay. */boolpacket_id_test (const struct packet_id_rec *p,		const struct packet_id_net *pin){  static int max_backtrack_stat;  packet_id_type diff;  msg (D_PID_DEBUG,       "PID TEST " time_format ":" packet_id_format " " time_format ":" packet_id_format "",       (time_type)p->time, (packet_id_print_type)p->id, (time_type)pin->time,       (packet_id_print_type)pin->id);  ASSERT (p->initialized);  if (!pin->id)    return false;  if (p->seq_backtrack)    {      /*       * In backtrack mode, we allow packet reordering subject       * to the seq_backtrack and time_backtrack constraints.       *       * This mode is used with UDP.       */      if (pin->time == p->time)	{	  /* is packet-id greater than any one we've seen yet? */	  if (pin->id > p->id)	    return true;	  /* check packet-id sliding window for original/replay status */	  diff = p->id - pin->id;	  /* keep track of maximum backtrack seen for debugging purposes */	  if ((int)diff > max_backtrack_stat)	    {	      max_backtrack_stat = (int)diff;	      msg (D_BACKTRACK, "Replay-window backtrack occurred [%d]", max_backtrack_stat);	    }	  if (diff >= (packet_id_type) CIRC_LIST_SIZE (p->seq_list))	    return false;	  return CIRC_LIST_ITEM (p->seq_list, diff) == 0;	}      else if (pin->time < p->time) /* if time goes back, reject */	return false;      else                          /* time moved forward */	return true;    }  else    {      /*       * In non-backtrack mode, all sequence number series must       * begin at 1 and must increment linearly without gaps.       *       * This mode is used with TCP.       */      if (pin->time == p->time)	return pin->id == p->id + 1;      else if (pin->time < p->time) /* if time goes back, reject */	return false;      else                          /* time moved forward */	return pin->id == 1;    }}/* * Read/write a packet ID to/from the buffer.  Short form is sequence number * only.  Long form is sequence number and timestamp. */boolpacket_id_read (struct packet_id_net *pin, struct buffer *buf, bool long_form){  packet_id_type net_id;  net_time_t net_time;  pin->id = 0;  pin->time = 0;  if (!buf_read (buf, &net_id, sizeof (net_id)))    return false;  pin->id = ntohpid (net_id);  if (long_form)    {      if (!buf_read (buf, &net_time, sizeof (net_time)))	return false;      pin->time = ntohtime (net_time);    }  return true;}boolpacket_id_write (const struct packet_id_net *pin, struct buffer *buf, bool long_form, bool prepend){  packet_id_type net_id = htonpid (pin->id);  net_time_t net_time = htontime (pin->time);  if (prepend)    {      if (long_form)	{	  if (!buf_write_prepend (buf, &net_time, sizeof (net_time)))	    return false;	}      if (!buf_write_prepend (buf, &net_id, sizeof (net_id)))	return false;    }  else    {      if (!buf_write (buf, &net_id, sizeof (net_id)))	return false;      if (long_form)	{	  if (!buf_write (buf, &net_time, sizeof (net_time)))	    return false;	}    }  return true;}const char *packet_id_net_print (const struct packet_id_net *pin, bool print_timestamp, struct gc_arena *gc){  struct buffer out = alloc_buf_gc (256, gc);  buf_printf (&out, "[ #" packet_id_format, (packet_id_print_type)pin->id);  if (print_timestamp && pin->time)      buf_printf (&out, " / time = (" packet_id_format ") %s", 		  (packet_id_print_type)pin->time,		  time_string (pin->time, 0, false, gc));  buf_printf (&out, " ]");  return BSTR (&out);}/* initialize the packet_id_persist structure in a disabled state */voidpacket_id_persist_init (struct packet_id_persist *p){  p->filename = NULL;  p->fd = -1;  p->time = p->time_last_written = 0;  p->id = p->id_last_written = 0;}/* close the file descriptor if it is open, and switch to disabled state */voidpacket_id_persist_close (struct packet_id_persist *p){  if (packet_id_persist_enabled (p))    {      if (close (p->fd))	msg (D_PID_PERSIST | M_ERRNO, "Close error on --replay-persist file %s", p->filename);      packet_id_persist_init (p);    }}/* load persisted rec packet_id (time and id) only once from file, and set state to enabled */voidpacket_id_persist_load (struct packet_id_persist *p, const char *filename){  struct gc_arena gc = gc_new ();  if (!packet_id_persist_enabled (p))    {      /* open packet-id persist file for both read and write */      p->fd = open (filename,		    O_CREAT | O_RDWR | O_BINARY,		    S_IRUSR | S_IWUSR);      if (p->fd == -1)	{	  msg (D_PID_PERSIST | M_ERRNO,	       "Cannot open --replay-persist file %s for read/write",	       filename);	}      else	{	  struct packet_id_persist_file_image image;	  ssize_t n;#if defined(HAVE_FLOCK) && defined(LOCK_EX) && defined(LOCK_NB)	  if (flock (p->fd, LOCK_EX | LOCK_NB))	    msg (M_ERR, "Cannot obtain exclusive lock on --replay-persist file %s", filename);#endif	  p->filename = filename;	  n = read (p->fd, &image, sizeof(image));	  if (n == sizeof(image))	    {	      p->time = p->time_last_written = image.time;	      p->id = p->id_last_written = image.id;	      msg (D_PID_PERSIST_DEBUG, "PID Persist Read from %s: %s",		   p->filename, packet_id_persist_print (p, &gc));	    }	  else if (n == -1)	    {	      msg (D_PID_PERSIST | M_ERRNO,		   "Read error on --replay-persist file %s",		   p->filename);	    }	}    }  gc_free (&gc);}/* save persisted rec packet_id (time and id) to file (only if enabled state) */voidpacket_id_persist_save (struct packet_id_persist *p){  if (packet_id_persist_enabled (p) && p->time && (p->time != p->time_last_written ||						   p->id != p->id_last_written))    {      struct packet_id_persist_file_image image;      ssize_t n;      off_t seek_ret;      struct gc_arena gc = gc_new ();      image.time = p->time;      image.id = p->id;      seek_ret = lseek(p->fd, (off_t)0, SEEK_SET);      if (seek_ret == (off_t)0)	{	  n = write(p->fd, &image, sizeof(image));	  if (n == sizeof(image))	    {	      p->time_last_written = p->time;	      p->id_last_written = p->id;	      msg (D_PID_PERSIST_DEBUG, "PID Persist Write to %s: %s",		   p->filename, packet_id_persist_print (p, &gc));	    }	  else	    {	      msg (D_PID_PERSIST | M_ERRNO,		   "Cannot write to --replay-persist file %s",		   p->filename);	    }	}      else	{	  msg (D_PID_PERSIST | M_ERRNO,	       "Cannot seek to beginning of --replay-persist file %s",	       p->filename);	}      gc_free (&gc);    }}/* transfer packet_id_persist -> packet_id */voidpacket_id_persist_load_obj (const struct packet_id_persist *p, struct packet_id *pid){  if (p && pid && packet_id_persist_enabled (p) && p->time)    {      pid->rec.time = p->time;      pid->rec.id = p->id;    }}const char *packet_id_persist_print (const struct packet_id_persist *p, struct gc_arena *gc){  struct buffer out = alloc_buf_gc (256, gc);  buf_printf (&out, "[");  if (packet_id_persist_enabled (p))    {      buf_printf (&out, " #" packet_id_format, (packet_id_print_type)p->id);      if (p->time)	buf_printf (&out, " / time = (" packet_id_format ") %s",		    (packet_id_print_type)p->time,		    time_string (p->time, 0, false, gc));    }  buf_printf (&out, " ]");  return (char *)out.data;}#if 1 // JYFIXME was: #ifdef PID_TESTvoidpacket_id_interactive_test (){  struct packet_id pid;  struct packet_id_net pin;  bool long_form;  bool count = 0;  bool test;  const int seq_backtrack = 10;  const int time_backtrack = 10;  packet_id_init (&pid, seq_backtrack, time_backtrack);  while (true) {    char buf[80];    if (!fgets(buf, sizeof(buf), stdin))      break;    update_time ();    if (sscanf (buf, "%lu,%u", &pin.time, &pin.id) == 2)      {	packet_id_reap_test (&pid.rec);	test = packet_id_test (&pid.rec, &pin);	printf ("packet_id_test (" time_format ", " packet_id_format ") returned %d\n",		(time_type)pin.time,		(packet_id_print_type)pin.id,		test);	if (test)	  packet_id_add (&pid.rec, &pin);      }    else      {	long_form = (count < 20);	packet_id_alloc_outgoing (&pid.send, &pin, long_form);	printf ("(" time_format "(" packet_id_format "), %d)\n",		(time_type)pin.time,		(packet_id_print_type)pin.id,		long_form);	if (pid.send.id == 10)	  pid.send.id = 0xFFFFFFF8;	++count;      }  }  packet_id_free (&pid);}#endif#endif /* USE_CRYPTO */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美在线观看一二区| 亚洲国产精品久久久久秋霞影院| 视频一区欧美日韩| 91精品婷婷国产综合久久性色| 日韩电影在线免费看| 欧美一区二区视频观看视频| 久久精品国产网站| 久久久91精品国产一区二区三区| 成人午夜大片免费观看| 中文字幕一区二区三区在线观看| 在线免费视频一区二区| 五月天网站亚洲| 国产午夜精品一区二区三区四区| www.日韩av| 天天综合日日夜夜精品| 精品三级av在线| www.久久久久久久久| 亚洲成人午夜电影| 2019国产精品| 欧洲人成人精品| 美女诱惑一区二区| 国产精品全国免费观看高清| 欧洲一区在线观看| 精品一区二区三区在线播放 | 色婷婷亚洲婷婷| 丝袜诱惑制服诱惑色一区在线观看| 日韩免费视频线观看| 成人av资源在线| 五月天欧美精品| 国产精品入口麻豆九色| 欧美日韩高清一区二区三区| 国产老女人精品毛片久久| 亚洲人吸女人奶水| 精品欧美一区二区三区精品久久 | 91在线免费播放| 视频一区视频二区中文| 中文字幕不卡在线观看| 7777精品久久久大香线蕉 | 国产精品久久久久永久免费观看| 日韩欧美一级精品久久| 国产一区二区三区免费| 亚洲国产一区在线观看| 欧美高清在线视频| 日韩一区二区三区精品视频| 在线视频一区二区三区| 国产成人精品免费看| 日韩高清不卡一区二区三区| 亚洲三级久久久| 国产亚洲美州欧州综合国 | 欧美日本在线视频| www.亚洲精品| 国产乱人伦偷精品视频不卡| 日韩中文字幕1| 亚洲一区二区三区自拍| 国产精品美女久久久久久久久久久| 日韩女同互慰一区二区| 欧美日韩美女一区二区| 色狠狠色噜噜噜综合网| 99久久精品费精品国产一区二区| 久久99热狠狠色一区二区| 亚洲aⅴ怡春院| 亚洲嫩草精品久久| 中文字幕一区二区三区四区| 国产亲近乱来精品视频| 日韩精品一区二区三区中文不卡| 欧美日本在线播放| 欧美体内she精高潮| 在线亚洲+欧美+日本专区| 99精品欧美一区二区三区小说| 国产91丝袜在线观看| 国产精品一二三在| 国模少妇一区二区三区| 国产呦萝稀缺另类资源| 久久精品av麻豆的观看方式| 日本中文字幕一区| 日本成人在线电影网| 丝袜国产日韩另类美女| 午夜精品福利一区二区三区av| 亚洲国产一区视频| 无码av免费一区二区三区试看| 亚洲福利国产精品| 日本中文字幕一区| 狠狠色综合日日| 国产成人综合在线| www.在线成人| 在线视频观看一区| 欧美视频在线观看一区| 欧美挠脚心视频网站| 3atv在线一区二区三区| 精品国产不卡一区二区三区| 免费黄网站欧美| 国产精品无码永久免费888| 久久精品一二三| 国产精品久久综合| 亚洲免费观看高清完整版在线观看| 亚洲色图一区二区| 亚洲高清在线视频| 奇米精品一区二区三区在线观看| 九九国产精品视频| 成人黄色a**站在线观看| 91香蕉视频黄| 777亚洲妇女| 国产亚洲欧美一区在线观看| 亚洲图片激情小说| 污片在线观看一区二区| 国产成人综合在线观看| 日本道色综合久久| 精品久久人人做人人爽| 国产精品每日更新| 亚洲福利国产精品| 国产精品一二三四| 欧美在线三级电影| 欧美电视剧免费观看| 中文字幕日韩一区二区| 依依成人精品视频| 久久九九影视网| 中文文精品字幕一区二区| 综合久久一区二区三区| 天天av天天翘天天综合网色鬼国产| 激情五月婷婷综合网| 在线日韩av片| 久久夜色精品一区| 亚洲一区二区三区自拍| 国产精品一区二区三区乱码| 一本一本大道香蕉久在线精品 | 香蕉av福利精品导航| 国产一区在线观看视频| 色老汉一区二区三区| 精品久久久久久久久久久久久久久久久 | 欧美日韩你懂得| 久久精品视频在线看| 一区二区国产盗摄色噜噜| 久久99国产精品成人| 欧美亚州韩日在线看免费版国语版| 久久美女高清视频| 五月天丁香久久| 91免费版在线| 久久婷婷国产综合国色天香| 舔着乳尖日韩一区| 色综合久久66| 久久精品免费在线观看| 免费观看成人鲁鲁鲁鲁鲁视频| 色中色一区二区| 国产精品国产成人国产三级| 精品一区二区精品| 91精品国产高清一区二区三区 | 99热国产精品| 亚洲精品一区二区三区香蕉 | 中文字幕在线观看不卡| 精品午夜久久福利影院| 在线不卡欧美精品一区二区三区| 亚洲美女区一区| 99国产麻豆精品| 国产精品另类一区| 国产成人福利片| 久久综合色综合88| 激情文学综合丁香| 日韩欧美中文一区| 婷婷成人综合网| 欧美一区二区三区在线电影| 亚洲国产美女搞黄色| 欧美性一二三区| 午夜天堂影视香蕉久久| 欧美午夜免费电影| 亚洲bt欧美bt精品| 欧美精品777| 日本成人超碰在线观看| 91精品在线免费观看| 日韩精品1区2区3区| 欧美一级一级性生活免费录像| 日韩国产在线一| 7777精品伊人久久久大香线蕉| 丝袜亚洲另类丝袜在线| 91精品国产高清一区二区三区 | 色综合色综合色综合| 亚洲国产精品精华液ab| 成人一区二区三区视频在线观看| 久久嫩草精品久久久精品一| 国产福利精品一区二区| 国产精品系列在线| 99久久久精品免费观看国产蜜| 亚洲欧美日韩国产综合| 欧美亚洲综合在线| 日本sm残虐另类| 久久丝袜美腿综合| av电影一区二区| 一区二区三区欧美| 欧美一区二区三区人| 国产麻豆精品一区二区| 中文字幕五月欧美| 欧美精品乱码久久久久久按摩| 日韩精品乱码免费| 久久久影视传媒| 91在线观看地址| 午夜视频一区二区三区| 精品国产乱码久久久久久老虎| 成人精品小蝌蚪| 亚洲电影视频在线| 久久久99精品免费观看不卡| 色激情天天射综合网|