/我手敲的代码(中文注释)/chapter11/volatility-2.3/build/lib/volatility/plugins/sockets.py
https://github.com/giantbranch/python-hacker-code · Python · 72 lines · 39 code · 10 blank · 23 comment · 6 complexity · 6c51560a4a295023ea15a2bdc214af9a MD5 · raw file
- # Volatility
- #
- # Authors:
- # Mike Auty <mike.auty@gmail.com>
- #
- # This file is part of Volatility.
- #
- # Volatility is free software; you can redistribute it and/or modify
- # it under the terms of the GNU General Public License Version 2 as
- # published by the Free Software Foundation. You may not use, modify or
- # distribute this program under any other version of the GNU General
- # Public License.
- #
- # Volatility 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 Volatility. If not, see <http://www.gnu.org/licenses/>.
- #
- #pylint: disable-msg=C0111
- import volatility.plugins.common as common
- import volatility.debug as debug
- import volatility.win32 as win32
- import volatility.utils as utils
- import volatility.protos as protos
- class Sockets(common.AbstractWindowsCommand):
- """Print list of open sockets"""
- def __init__(self, config, *args, **kwargs):
- common.AbstractWindowsCommand.__init__(self, config, *args, **kwargs)
- config.add_option("PHYSICAL-OFFSET", short_option = 'P', default = False,
- cache_invalidator = False,
- help = "Physical Offset", action = "store_true")
- @staticmethod
- def is_valid_profile(profile):
- return (profile.metadata.get('os', 'unknown') == 'windows' and
- profile.metadata.get('major', 0) == 5)
- def render_text(self, outfd, data):
- offsettype = "(V)" if not self._config.PHYSICAL_OFFSET else "(P)"
- self.table_header(outfd,
- [("Offset{0}".format(offsettype), "[addrpad]"),
- ("PID", ">8"),
- ("Port", ">6"),
- ("Proto", ">6"),
- ("Protocol", "15"),
- ("Address", "15"),
- ("Create Time", "")
- ])
- for sock in data:
- if not self._config.PHYSICAL_OFFSET:
- offset = sock.obj_offset
- else:
- offset = sock.obj_vm.vtop(sock.obj_offset)
- self.table_row(outfd, offset, sock.Pid, sock.LocalPort, sock.Protocol,
- protos.protos.get(sock.Protocol.v(), "-"),
- sock.LocalIpAddress, sock.CreateTime)
- def calculate(self):
- addr_space = utils.load_as(self._config)
- if not self.is_valid_profile(addr_space.profile):
- debug.error("This command does not support the selected profile.")
- return win32.network.determine_sockets(addr_space)